web前端优化之图片优化

开发前端也有几年了,一直很忙,课下看书,或者做一些笔记,看看别人的见解,也会做一些笔记记录,有时间就来刷刷掘金,逛逛技术网站,尴尬的事情是自己没有认真的总结过一些笔记和知识点,发出来大家共同学习,最近也才开始做一些markdown,后续我会抽时间继续做这件事,有什么不对的知识点,麻烦大家指出批评,也算对自己的一个巩固。

很多的前端开发者都比较关心性能的优化的问题,今天主要讲一下图片优化的见解和总结,可能很多人大神都知道我列出的知识点,那么开始整理一下图片优化的笔记吧,可能废话有点多,语言组织不到位的地方,大家多担待

每个前端网站都有可能引入很多的图片来达到酷炫或者展示的效果,有人会问?为什么非要用图片,因为有些技术上达不到的效果展示,只能用图片来代替,比如淘宝天猫京东这些商城的酷炫的创意广告图
当然我们也会用到很多的图标图片,图片越多请求次数越多,造成延迟的可能性也就越大

最开始做前端的时候,我都会把实现不了的效果切换成图片还有一些图标也会切成图片,这样就会降低前端页面展示的性能增加页面资源HTTP的请求,甚至有的页面存在几十个imghttp请求

总结优化的地方有几个地方:

  • 1、降低图片的大小

首先我们目前常用的图片格式有png,gif,jpg等,png又分png24和png8,关于图片的的知识点,我给大家两个网址大家可以了解一下,对于图片格式讲的很详细
http://www.cnblogs.com/xiangism/p/5311314.html
http://www.cnblogs.com/pqjzxq/p/5749304.html

我们的目的是降低图片的大小kb,有很多方法可以做,压缩图片,选择更小kb的图片格式,以达到最优的显示效果

好多人都推荐一个压缩图片的网站---智图:一个图片优化平台
用起来很简单的

现在百度一下很多在线压缩图的在线网站,比如TinyPNG:一个压缩PNG的神站

  • 2、选择适当的图片宽度尺寸(即响应式图片)

不管是pc还是移动端,都会有很多不同尺寸的图片,如果你做的是响应式网站和移动端的话,那么你就更需要考虑图片尺寸的选择问题了

移动端的屏幕分辨率和尺寸太多,所以就可能需要不同的尺寸加载不同尺寸的图片,这样就节省了网站的访问流量,以及页面渲染的效率
先展示现在设备的分辨率等的图

如果想查看更多的话,就去devices

响应式图片方式有哪几种,

  • 可以通过服务器图片资源配置命名规则来获取图片

ps:![](bgimg-320.jpg)或![](bgimg-480.jpg) 
  • 通过css定义来加载不同的背景bg图片

@media only screen and (max-width : 480px) {
    .img {background-image: url(bg-480.jpg);}
}
@media only screen and (max-width : 360px) {
    .img {background-image: url(bg-360.jpg);}
}
  • Img的srcsetsizes的方法

这两个img属性是html5的属性,有浏览器的兼容问题

<img class="img"  src="imgbg-320.jpg"
     srcset="imgbg-320.jpg 320w, imgbg-360.jpg 360w, imgbg-480px.jpg 480w"
     sizes="(max-width: 480px) 480px, 320px">

src:当设备不支持srcsetsizes属性时,使用这个图片
srcset指定图片的地址和对应的图片质量。sizes用来设置图片的尺寸零界点

sizes="[media query] [length], [media query] [length] ... "

对于srcsetsizes详解点击查看

  • picture标签实现

通过媒体查询的方式,根据页面宽度(当然也可以添加其他参考项)加载不同图片,具体picture详情点击查看

<picture>  
    <source srcset="3.jpg" media="(min-width: 320px)">  
    <source srcset="2.jpg" media="(min-width: 480px)">  
    <img srcset="1.jpg">  
</picture> 
  • 3、减少HTTP的网络资源请求

  • CSSSprites(背景精灵图/雪碧图)

一种网页图片应用处理方式,将一个页面涉及到的所有零星图片或者图标都包含到一张大图里面,这样就只需要加载这个一个图片,而不是很多个图片了,这样就减少了很多http的请求

如何制作精灵图?

自己通过ps制作,或者UI设计师制作的过程中,做好这个精灵图,注意图片直接的间隔,以防css操作的时候出现显示的问题

怎么使用精灵图?

利用CSS的background-imagebackground- repeatbackground-position的组合进行背景定位,background-position可以用数字精确的定位出背景图片的位置
详细查看CSSSprites

  • csscss3制作简单的图标和动画(代替gif图片)

随着技术的发展,css3可以实现的效果越来越多,比如箭头图标,三角形,梯形等图标,或者一些阴影效果,渐变的效果,所以可以用css制作一些简单的图标,而且具有多变性

.sanjiaoxing {
    width: 0;
    height: 0;
    border-top: 2em solid #000;
    border-right: 1.8rem solid transparent;
    border-left: 1.8rem solid transparent;
}
  • SVG技术替换图片

SVG 是使用 XML 来描述二维图形和绘图程序的语言,支持透明,缩放,动画
什么是SVG?(摘自w3cschool)
SVG 指可伸缩矢量图形 (Scalable Vector Graphics)
SVG 用来定义用于网络的基于矢量的图形
SVG 使用 XML 格式定义图形
SVG 图像在放大或改变尺寸的情况下其图形质量不会有所损失
SVG 是万维网联盟的标准
SVG 与诸如 DOM 和 XSL 之类的 W3C 标准是一个整体

  • html5 canvas绘画图形

目前canvas应用很多,它可以使用脚本javascript来绘制各种图表、动画等
点击查看更多html5 canvas

  • 4、字体图库代替图标

随着技术的更新和浏览器的更新,字体图库去代替一些图标我认为还是极好的,使用字体图库你不仅可以改变大小,而且还可以改变颜色
大家比较熟知的的字体图库有很多,这里就说一个吧,font-awesom,截图看看他的好处吧

有了他,根本不担心图标的问题了,很简单的使用,只需要引入之后,按照规则写html标签即可

其实咱们也可以自定义咱们的图标选择,毕竟有的图标库我们用不到这么多,因此咱们可以自定义咱们的字体图标库

目前我认为毕竟好的就是 Iconfont ,最近的几个react项目,我都在使用这个来定制自己的一些图标库,用起来也很简单

  • 1、搜索自己想要的图标
2、在搜索结果页找到自己想要的图标,然后加入购物车
3、找完自己的图标之后点开购物车,会有一个添加到项目,点击它,如果你有项目就可以选择,如果没有就创建一个项目,点击确定之后即可
4、在个人中心找到自己的项目,选择方式之后,点击下载即可使用

使用方式在这里就不多说了,和font-awesom基本上差不多的

  • 5、微信小程序怎么使用字体图标

直接引入字体也可以,但是要把字体文件放在服务器上,并且允许跨域的情况下,在css文件里面远程地址引入字体文件即可

@font-face {font-family: "iconfont";
  src: url('https//examle.com/font/iconfont.eot?t=1494498562077'); /* IE9*/
  src: url('https//examle.com/font/iconfont.eot?t=1494498562077#iefix') format('embedded-opentype'), /* IE6-IE8 */
  url('https//examle.com/font/iconfont.woff?t=1494498562077') format('woff'), /* chrome, firefox */
  url('https//examle.com/font/iconfont.ttf?t=1494498562077') format('truetype'), /* chrome, firefox, opera, Safari, Android, iOS 4.2+*/
  url('https//examle.com/font/iconfont.svg?t=1494498562077#iconfont') format('svg'); /* iOS 4.1- */
}

如果不想放在服务器上,还有一种方法可以使用,这个时候我们需要一个工具来辅助一下 transfonter,将解压出来的ttf字体文件转化成base64格式

生成的文件里面替换css里面的代码

@font-face {
    font-family: 'iconfont';
    src: url(data:font/truetype;charset=utf-8;base64,这里省略了) format('truetype');
    font-weight: 500;
    font-style: normal;
}

使用和直接引入字体图标是一样的

  • 6、图片延迟加载(懒惰加载)(js/lazyload.js)

有个页面会很大很长很多的图片素材,这样全部加载就会变的很慢,因此需要修改一下加载方案,只加载窗口内的图片,我们大家浏览网站的时候会经常看到会有默认图,图片加载成功之后会替换默认图
比如常用的lazyload.js用于图片的延迟加载,视口外的图片会在窗口滚动到它的位置时再进行加载,这是与预加载相反的,。

  • 能有效的提高页面加载速度
  • 有时候可以帮助减少服务器负载

用法:lazyload.js

还有一些优化的方式在上一篇文章已经列了,这里就不多说了

如有没有说到的地方,麻烦大家指出

后续抽时间会接着做笔记,大家共同学习巩固分享

前端蜗牛blog传送:codehtml

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,858评论 25 707
  • 前言 前端的工作并不仅仅是实现「视觉&交互稿」,想要开发一个高性能易维护的「完美」站点并未易事,针对前端的性能优化...
    木羽zwwill阅读 630评论 0 4
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,066评论 4 62
  • 在我们的生命中,总会遇到一条让你犯错的大鱼,他也许叫鲲。 你犯下一个错 然后想弥补想还清 最后发现永远还不清 所有...
    白米饭_阅读 345评论 0 1
  • urllib2不验证ssl证书 随机User-Agent 安装PyV8 参考:http://shomy.top/2...
    black3y阅读 389评论 0 0