@lizlalala
2016-07-13T10:06:37.000000Z
字数 1282
阅读 2944
web原理
->解析HTML,生成DOM树
->解析css,生成渲染树(包含width,颜色等)
->对渲染树上的每一个节点定位、布局layout,确定在页面上的位置。
->遍历渲染树,绘制每一个节点
webkit:
当解析html的时候,会把新来的元素插入dom tree里面,同时去查找css
然后把对应的样式规则应用到元素上,查找样式表是按照从右到左的顺序去匹配的。
tips:(防止二次渲染)
指定img、table尺寸,如果浏览器可以立即决定图像或tables的大小,那么它就可以马上显示页面而不要重新做一些布局安排的工作,这不仅加快了页面的显示,也预防了页面完成加载后布局的一些不当的改变
image使用height和width
table使用table-layout: fixed并使用col和colgroup标签指定columns的width
css放head,script放后面。把CSS放到前面可以保证先渲染的一部分元素样式是正确的,而把CSS放到后面会引起大量的浏览器重绘。把script标签放到尾部,因为浏览器会预处理js文件,把js文件放到头部会延迟页面元素的渲染,让用户觉得页面打开变慢了。
【备注】立即执行式的,并不等页面渲染完。只有用到 onload 或者 监听
*document.addEventListener("DOMContentLoaded", handler, false)
才会等到页面完成时运行 function
且有修改dom操作,会因为找不到dom报错并跳过。
此时还在head部分,浏览器只会读取,生成树,并不渲染。
当第一次读到body部分时,开始渲染,每个标签边读边查找css样式表渲染
浏览器在代码中发现一个<img>标签引用了一张图片,向服务器发出请求。此时浏览器不会等到图片下载完,而是继续渲染后面的代码;