说走就走的性能优化之旅

雅虎规则

熟悉网站优化的开发者应该都知道,只要提到网页性能优化,就绕不开雅虎军规。优化规则&&原文,仔细阅读这些规则,可以总结到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变成延迟加载等等。

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

本文转载于:猿2048?https://www.mk2048.com/blog/blog.php?id=hh1222jaaaa

原文地址:https://www.cnblogs.com/homehtml/p/12584947.html

时间: 2024-10-28 10:56:08

说走就走的性能优化之旅的相关文章

PHP性能优化工具–xhprof安装

PHP性能优化工具–xhprof安装,这里我先贴出大致的步骤: 1.获取xhprof 2.编译前预处理 3.编译安装 4.配置php.ini 5.查看运行结果 那么下面我们开始安装xhprof工具吧: 1.获取xhprof 可以输入网址直接下载,或者wget 1 2 3 4 #wget http://pecl.php.net/get/xhprof-0.9.4.tgz #tar zxf xhprof-0.9.4.tgz 2.编译前预处理 在编译xhprof之前,先做一下预处理,生成configur

Sql Server查询性能优化之走出索引的误区

据了解绝大多数开发人员对于索引的理解都是一知半解,局限于大多数日常工作没有机会.也什么没有必要去关心.了解索引,实在哪天某个查询太慢了找到查询条件建个索引就ok,哪天又有个查询慢了,再建立个索引就是,或者干脆把整个查询SQL直接发给DBA,让DBA直接帮忙优化了,所以造成的状况就是开发人员对于索引的理解.认识很局限,以下就把我个人对于索引的理解及浅薄认识和大家分享下,希望能解除一些大家的疑惑,一起走出索引的误区 误区1.在表上建立了索引,在查询时用到了索引的列,索引就一定会生效 首先明确下这样的

走在性能优化的路上

35 个 Java 代码性能优化总结 转载于伟大的安卓巴士 Android开发中文站 ? 35 个 Java 代码性能优化总结 前言 代码优化,一个很重要的课题.可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?没用,但是,吃的小虾米一多之后,鲸鱼就被喂饱了.代码优化也是一样,如果项目着眼于尽快无BUG上线,那么此时可以抓大放小,代码的细节可以不精打细磨:但是如果有足够的时间开发.维护代

<20>【掌握】《走出迷宫》游戏代码实现+【理解】《走出迷宫》游戏优化

#include <stdio.h> #define COL 6 #define ROW 6 int main(int argc, const char * argv[]) { //****** 定义变量 ********** //1.定义变量,地图.存储用户输入的方向.小人的位置     char map[ROW][COL]={         {'#','#','#','#','#','#'},         {'#','O','#','#',' ',' '},         {'#'

Spark性能优化指南——高级篇

Spark性能优化指南--高级篇 [TOC] 前言 继基础篇讲解了每个Spark开发人员都必须熟知的开发调优与资源调优之后,本文作为<Spark性能优化指南>的高级篇,将深入分析数据倾斜调优与shuffle调优,以解决更加棘手的性能问题. 数据倾斜调优 调优概述 有的时候,我们可能会遇到大数据计算中一个最棘手的问题--数据倾斜,此时Spark作业的性能会比期望差很多.数据倾斜调优,就是使用各种技术方案解决不同类型的数据倾斜问题,以保证Spark作业的性能. 数据倾斜发生时的现象 绝大多数tas

MySQL 性能优化的最佳20多条经验分享

今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的                    事,而这更是我们程序员需要去关注的事情. 当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能.这里,我们不会讲过多的SQL语                句的优化,而只是针对MySQL这一Web应用最多的数据库.希望下面的这些优化技巧对你有用. 1. 为查询缓存优化你的查询 大多数的M

MySQL性能优化的最佳20+条经验

http://www.pythonclub.org/mysql/optimize-20-tips 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情.当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能.这里,我们不会讲过多的SQL语句的优化,而只是针对MySQL这一Web应用最多的数据库.希望下面的这些优化技巧对你有用. 1. 为查询缓存

Redis各种数据结构性能数据对比和性能优化实践

很对不起大家,又是一篇乱序的文章,但是满满的干货,来源于实践,相信大家会有所收获.里面穿插一些感悟和生活故事,可以忽略不看.不过听大家普遍的反馈说这是其中最喜欢看的部分,好吧,就当学习之后轻松一下. Redis各种数据结构性能数据对比 测试工具:perf4j 性能指标:平均值,最小值,最大值,方差 对比将814条数据按单条插入到哈希MAP和哈希SET: 对比从814条数据的哈希MAP和哈希SET中判断一个元素是否存在(map的hasKey和set的isMember): 大量数据插入哈希MAP,运

CSS3与页面布局学习总结(八)——浏览器兼容与前端性能优化

目录 一.浏览器兼容 1.1.概要 1.2.浏览器内核 1.3.浏览器市场份额(Browser Market Share) 1.4.兼容的一般标准 1.5.CSS Reset 1.6.CSS Hack 1.6.1.条件注释法 1.6.2.样式内属性标记法 1.6.3.选择器前缀法 1.7.文档模式 (X-UA-Compatible) 1.8.javascript兼容 二.前端性能优化 2.1.概要 2.2.减少HTTP请求数量 2.2.1.图片地图 2.2.2.精灵图片(Sprite) 2.2.