说走就走的性能优化之旅

雅虎规则

熟悉网站优化的开发者应该都知道,只要提到网页性能优化,就绕不开雅虎军规。优化规则&&原文,仔细阅读这些规则,可以总结到3个方面:

Http层面上的优化

减少http请求数,http请求cookie减小,减少DNS查询,避免跳转,ajax利用缓存之类,都是在http层面上的考虑。

静态资源

压缩js和css代码,使用gzip,利用CDN(也可以算http层面上),避免CSS表达式,优化和裁剪图片之类的,都可以算作为静态资源上的优化,其实和Http很多有交集的。

页面加载

前置css,后置js,首屏无关的不加载,图片懒加载,精简DOM之类的,都是在网页加载层面上的优化,可以算作请求都结束了之后做的东西。

所以说,我们在做页面优化的时候,基本都是从这些方面来考虑的,那么我今天要说的是,另外的角度考虑优化或者说从体验上来做的优化。

回忆过去

优化后

优化前

如果网速不错,在电脑上,基本感觉不出2个有什么区别,加上浏览器的缓存的话,后面的区别就更小了。

优化后截图
优化前截图

为什么没有区别,因为资源都是一样的,而且都放在阿里的CDN上面,去除掉网络波动,总体上来说就是应该没有什么区别,那么为什么还是要优化,如果你使用一点弱网络(不要太弱,太弱又差不多了)就慢慢能看出来,优化后明显页面出来的速度比优化前要快,嘿嘿!!!

为什么?

寻找目的地

先分析我们目的是什么,是加快页面显示的速度,并非加快页面整个加载速度,因为基本上这个页面能从Http和静态上优化的点快做完了,静态都在CDN上面,就一个html,没了。所以我们只能用页面显示速度上做文章了。

怎么搞?

注意截图中红色画框的部分和红色箭头,这部分明显的是有区别的,这个红线的时间,表示的是什么,就是你浏览器转圈圈的时间,放在微信下就是那个绿条的时间,表示你页面首屏加载完成了,要优化的也是这个。

第一道风景--火焰山

最先想到的是图片问题,懒加载模式,这样子,所有的图片就会像优化后的页面一样,在红线的后面。但是这种懒加载有几个问题:

  1. 我们页面是放在App里面的,会记录文章浏览位置,再次进来的时候,Native会设置position来到达自动回到阅读位置的效果,这个效果会导致我们判断图片是否在当前屏幕有误差,就会显示背景色,体验很不好。

2.在移动端使用scroll方法来判断是否滚屏,会有误差,因为浏览器触发这个事件是在滚动停止后才触发的,也就是滚动不停止就会一直不触发,造成了加载的误差。

对于2可以换监听方式来解决,例如监听touchmove。

但是第一个就比较尴尬了,除非用回调之类的形式,所以我换了一个思路,我们的使用懒加载的原因是为了把图片延后,让其他的静态提前加载。并非像淘宝一样,因为图片众多,要分屏幕一屏一屏的分批加载,基于上面的考虑,我修改完全的懒加载模式变成延迟加载模式,意思是在js最前面执行文章内容的所有图片立即加载,也就解决了上述的1,2问题。同时达到了最初的目的。

第二道--通天河

刚翻过了几座山
又越过了几条河
崎岖坎坷怎么他就这么多

情不自禁的哼了起来,解决了图片的问题之后,发现一个原来一直没有注意的问题,静态加载资源也是有优先级的,看页面代码,我们其实把font-face放置的很前,在css,img,js之前,但是仔细看
font加载的顺序一直在css和js之后,由于使用了font-face,就导致了,字体没有加载出来之前,页面文字不显示或者闪烁一下,这就是我前面说到的弱网络的环境下,优化后的页面显示(不是加载)的快。

代码顺序

如何解决呢? 方案类似于图片,延迟加载,怎么个延迟 --- 我使用的方案是在html最后,嵌入一段script,里面代码用setTimeout,0ms,添加我们的业务js代码,这样子就变成优化后截图的效果了,很明显的最后一个js在红线之后,font加载顺序提前了。

最后在翻查了各种文档之后,找到了原因,字体官方文档

注意这里:if a font face isn’t *currently* used by anything on a page, most user agents will not download its associated file. This means that later use of the font face will incur a delay as the user agent finally notices a usage and begins downloading and parsing the font file.

font-load事件

其实也就是说,浏览器先分析了页面的情况,才决定是否需要加载相关字体(过于智能有时候好麻烦!!!),所以有一个办法来优先加载字体资源就是用浏览器给的API:

 var f = new FontFace("newfont", "url(newfont.woff)", {});
  f.load().then(function (loadedFace) {
  document.fonts.add(loadedFace);
  document.body.style.fontFamily = "newfont, serif";
});

当然了,思路就如上所述,其实还有优化的空间,例如再精简我们js大小,css大小,把一个前置的js动画依赖,mo.min.js变成延迟加载等等。

文章的主旨并非讲解通用的优化方法,而是我当时优化的思路,通过当时思考的思路,来启示大家在做优化的时候,不要盲目的就只会按照别人的方法来,要多思考,多查阅相关文档。

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

推荐阅读更多精彩内容