提高浏览器渲染页面速度的建议
来源:学问馆 本文已影响3.07W人
来源:学问馆 本文已影响3.07W人
怎样尽可能的缩短浏览器上页面渲染的时间,文章从以下几方面着手:
写出高效的css代码
避免使用css表达式
把css文件放在页面顶部
指定页面图片的尺寸
页面头部标明文档编码
一,写出高效的css代码
首先弄清浏览器解析html代码的过程:构建一个dom树,页面要显示的各元素都会创建到这个dom树当中。每当一个新元素加入到这个dom树当 中,浏览器便会通过css引擎查遍css样式表,找到符合该元素的样式规则应用到这个元素上。css引擎查找样式表,对每条规则都按从右到左的顺序去匹 配。
了解过程后,我们可以看出可以从两方面优化我们的css代码:1,定义的css样式规则条数越少越好,所以赶紧删除css文件中不必要的'样式定 义;2,优化每条规则的选择符书写方式,尽量让css引擎一看就知道这个规则是否需要应用到当前这个元素上,让引擎少走不必要的弯路。
如以下几种效率不高的css书写方式:
body * {...}
hide-scrollbars * {...}
b, 用标签做关键选择符
ul li a {...}
#footer h3 {...}
* html #atticPromo ul li a {...}
c, 画蛇添足的写法
ul#top_blue_nav {...}
form#UserLogin {...}
d, 给非连接标签添加 :hover 伪类,这会对用了strict doctype的页面在IE7和IE8下变的很慢。
h3:hover {...}
:hover {...}
#foo:hover {...}
:hover {...}
优化建议:
a, 避免使用通配符;
b, 让css引擎快速辨别该规则是否适用于当前元素:多用id或class选择符,少用标签选择符;
c, 不要画蛇添足把id和class或标签和class等连着写;
d, 尽量避免使用后代选择符,去除不必要的祖先元素,可以考虑使用class选择符来替换后代选择符;
/*给无序和有序的li定义不同颜色,你可能会这样写:*/
ul li {color: blue;}
ol li {color: red;}
/*给li添加class,这样定义效率会更高:*/
dered-list-item {color: blue;}
red-list-item {color: red;}
e, 避免给非连接标签添加 :hover 伪类。
二,避免使用css表达式
css表达式仅在ie浏览器下才起作用,微软已在ie8后不推荐使用,因为它会严重影响页面性能:任何时候,不管任何一个事件被触发,例如窗口的 resize 事件,鼠标的移动等等,css表达式都会重新计算一遍。
三,把css文件放在页面顶部
把外联或内联样式表放在body部分会影响页面渲染的速度,因为浏览器只有在所有样式表下载完成后才会继续下载页面其他内容。
ie浏览器在哪里--如何设置
如何使用智能浏览器广告拦截的功能教程
猎豹浏览器广告里的“备胎猫”是专业演员么?
浏览器亚像素渲染与小数位的取舍
“七成国企上调年终奖”不宜过度渲染
三星S8多角度渲染图首曝!
怎么评价QQ浏览器(PC版)?
信息技术《浏览网页》教学反思范文
电脑浏览器快捷键
win7系统怎么设置默认浏览器
信息技术《浏览网页》教学反思
2017年什么浏览器比较好用-网站大全
关于Win10的系统浏览器是什么
uc浏览器电脑版无法卸载的应对措施
议论文阅读:关掉你那个破浏览器
14个最知名的手机浏览器推荐
360安全浏览器广告拦截设置
Win7怎么屏蔽浏览器广告弹出框?
提高面试效率的几点建议
网页设计实习生提高设计速度工作效率的方法
苹果手机哪个浏览器最快
安卓手机哪个浏览器最好用
XP系统的IE浏览器怎么卸载?
如何提高简历的浏览量
枫树浏览器被腾讯收购了吗?
qq隐身状态下看了你发的说说,浏览选项能看到该次浏览吗?