轩枫阁V3主题已上线,本文将介绍本站V3主题关于加载优化的内容。
关于图片,这里使用传统的优化方式。本站使用的图片主要有各类图标、大图、文章配图、文章内容图等。
使用雪碧图Sprite
,将各图标合并成一张图,可以减少HTTP
请求数。
开发过程中,使用单个图标,结合tmt-workflow
,在发布时将图片合并。同时移动端支持2倍雪碧图,只需同时将2x
图标放至slice目录即可。
图标、大图、配图、内容图在制作的过程中,可以在PS中,使用快捷键Ctrl+Shift+Alt+S
,保存为Web
可用格式。半透明图一般选择PNG24
,其它图片(色彩丰富)一般保存为质量为高的JPG
格式图。
除了文章图,其它图片可以通过tmt-workflow
构建,将图片进行压缩。PNG图片的压缩率一般在40%,JPG的压缩率一般在20%,具体根据图片。
对于文章内容,使用lazyload
非常的普遍。在用户滚动时,才提前加载显示相应的图片,保证页面打开速度。WP
中使用lazyload
也很简单。
1. 首先需要在functions.php
中将img标签的src
替换成base64
灰色图
// lazyload function lazyload($content) { if(!is_feed() || !is_robots) { $content = preg_replace('/<img(.+)src=[\'"]([^\'"]+)[\'"](.*)>/i',"<img class=\"lazyload\" \$1data-original=\"\$2\" src=\"\"\$3>\n", $content); } return $content; } // 文章内容 add_filter('the_content', 'lazyload'); // 文章配图 add_filter('post_thumbnail_html', 'lazyload');
2. 使用lazyload.js
滚动加载图片
建议使用这个版本:https://github.com/jieyou/lazyload
$("img.lazyload").lazyload({ effect: "show", data_attribute: 'original', threshold: 100 });
js文件放底部
HTTP/1.1
协议中建议浏览器不在同一域名下并行下载多于两个的资源。假如你的图片是在多个域名下的,你可以并行下载超过两张的图片。可是一个脚本在下载的时候,浏览器不能再开始其他的下载,即使在不同的域名下。css样式表合并放头部
Head
可以让页面加载的更快,这是因为将样式表放在头部有利于页面渲染外链文件
js
、css
进行外链,使用缓存,加快用户第一次以后访问页面的速度压缩合并JS、CSS文件,减少HTTP请求数。
WP可以结合七牛资源镜像CDN
,加快文件下载速度。
轩枫阁移动端针对JS文件进行了本地存储处理。
js文件在构建时,加上版本号,如main.bc9db071.js
。
页面在打开时,会从localstorage
里读取是否有当前版本的js文件,如果有则从LS中读取,否则下载后存储。
只有当下次上线更新文件时,会重新下载JS文件。