web前端优化--图片优化

今天逛掘金浏览到一片有关web前端优化之图片优化的文章,很详细,比我这里总结的都全,大家可移步浏览:
https://juejin.im/post/59a7725b6fb9a02497170459
文章中除了自己之前用到的,还有img的srcset和sizes的方法没用过,
我先总结下方法:

     1. 降低图片的大小
     2. CSS Sprites(雪碧图)
     3. 字体图标
     4. 图片懒加载(lazyload.js)

接着,详细解说下:

一、降低图片的大小

这里主推两个小工具: TinyPNG:网称压缩PNG的神站 (支持png和jpg); 智图 (支持png,jpg,webp),可大大降低图片的大小

注:webp是Google于2010年提出了一种新的图片压缩格式,14年又提出了动态WebP,目前只有谷歌内核可支持。

刚才有get到一个新的图片自适应技术– SharpP,后面再补充。

二、CSS Sprites(雪碧图/精灵图)

在线工具:CSS Sprites,超好用,不用麻烦UI去设计了,还可选择图片排列顺序,重点是可以直接生成代码,不用再去手动测量了,很方便。

三、字体图标

为 Bootstrap而创造的图标字体:font-awesome(具体操作不再啰嗦)
阿里巴巴矢量图标库:iconfont
介绍下iconfont的使用,进入官网,直接搜索要找的图标,比如:短信,可以看下以下界面:

web前端优化--图片优化_第1张图片

可以加入库、收藏或直接下载,选择直接下载,可以看到这里能够选择颜色和下载的格式:(看下图)

web前端优化--图片优化_第2张图片

要下载多个的话,就先加入库中,点击右上角的购物车图标,按照上面提示的步骤来,添加项目….(可创建多个项目,不同的项目使用不同的图标,方便管理),最后下载还可以生成在线链接

web前端优化--图片优化_第3张图片

四、图片懒加载(lazyload.js)

前段时间做项目正好用到这个,记录下;

lazyload.js用于长页面图片的延迟加载,视口外的图片会在窗口滚动到它的位置时再进行加载,这是与预加载相反的。可提高页面加载速度、减少服务器负载。

实现步骤:

 1. 首先下载lazyload.js,该插件依赖于jQuery,所以需要先加载jq;
 2. 将图片的真实路径写入data-original属性
 3. 给这些图片增加一个名为lazy的class
 4. 选择所有要lazyload的图片(img.lazy),执行lazyload();

注意:必须设置图片的高度或者宽度,否则插件可能无法正常工作.

web前端优化--图片优化_第4张图片

<script src="js/jquery-1.11.0.min.js">script>
<script src="js/jquery.lazyload.min.js">script>
<script type="text/javascript">
    /* 延时加载网页中除首屏图片之外的其它图片 */
    $("img.lazy").lazyload({
        effect: "fadeIn",   //载入方式
        skip_invisible: false,
        failurelimit: 2
    });
script>   

来任务了,先写这么多,后期补充。

你可能感兴趣的:(web前端优化)