游戏攻略网
当前位置: 首页 游戏攻略

为什么浏览器内核不好开发(浏览器有哪些内核)

时间:2023-05-26 作者: 小编 阅读量: 3 栏目名: 游戏攻略

常见的浏览器内核:四大内核:1、Trident内核,也称IE内核。内部js脚本会在引入它的位置执行,外联脚本则是加载完毕后执行。则就叫称为重绘。因此回流必定影响重绘,重绘不一定引起回流。回流比重绘的代价要更高2.回流何时发生当页面布局和几何属性改变时就需要回流。比如修改100次,然后再把他显示出来。不要把DOM结点的属性值放在一个循环里当成循环的变量。DOM树要小,CSS尽量用id和class,千万不要过渡层叠下去。

一. 浏览器内核

浏览器的功能:显示在计算机中的网页实际上是位于许多不同的计算机文件中的元素的集合。因此,浏览器的功能首先是检索文件,然后将页面的各个部分组合起来,根据文本中的HTML命令排列这些部分。

浏览器内核分为两部分:渲染引擎 JavaScript引擎。其中,渲染引擎是浏览器内核中比较重要的部分,现在所说的内核一般指的都是渲染引擎。

常见的浏览器内核:

四大内核

1、Trident内核,也称IE内核。

2、Webkit内核。

3、Gecko内核。

4、Presto内核。

各浏览器所用内核:

1、IE浏览器内核:Trident内核,也是俗称的IE内核;

2、Chrome浏览器内核:统称为Chromium内核或Chrome内核,以前是Webkit内核,现在是Blink内核;

3、Firefox浏览器内核:Gecko内核,俗称Firefox内核;

4、Safari浏览器内核:Webkit内核;

5、Opera浏览器内核:最初是自己的Presto内核,后来是Webkit,现在是Blink内核;

6、360浏览器、猎豹浏览器内核:IE Chrome双内核;

7、搜狗、遨游、QQ浏览器内核:Trident(兼容模式) Webkit(高速模式);

8、百度浏览器、世界之窗内核:IE内核;

9、2345浏览器内核:以前是IE内核,现在也是IE Chrome双内核;

二. 浏览器显示页面的步骤

1. 从网络层(networking)获取请求文档的内容,解析HTML/SVG/XHTML,形成一个DOM树(DOM Tree)

默认情况下,加载和执行javascript都会阻止DOM tree的构建。

内部js脚本会在引入它的位置执行,外联脚本则是加载完毕后执行。

注意:因此,不管是内联脚本还是外部脚本,都应该尽量放在标签结束之前(除非某些脚本需要在页面加载完之前调用),这样可以保证在运行脚本之前,页面已经基本加载完成。

2. 解析CSS代码,计算出最终的样式数据,产生一个CSS规则树(CSS Rule Tree)

解析CSS的时候的顺序:浏览器默认设置,用户设置,外链样式,内联样式,html中的style

3. 解析JavaScript

通过DOM API来操作DOM Tree,通过CSSOM API来操作CSS Rule Tree

4. 解析完上述三种代码之后,就构建一个渲染树 (rendering tree)

渲染树和DOM树有所不同:

渲染树中不包括不需要渲染的节点 : html head meta link style script display : none的元素,渲染树中每一个节点都储存有对应的CSS属性,加载css会阻止render tree的构建

5. 开始渲染,页面初始化时会发生一次回流

三. 页面的重绘和回流

1. 什么是页面的重绘和回流

回流:当render tree中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构建。(需要改变布局、几何属性)

重绘:当render tree中的一些元素需要更新属性,而这些属性只是影响元素的外观,风格,而不会影响布局的,比如background-color。则就叫称为重绘。

因此回流必定影响重绘,重绘不一定引起回流。回流比重绘的代价要更高

2. 回流何时发生

当页面布局和几何属性改变时就需要回流。下述情况会发生浏览器回流:

1、添加或者删除可见的DOM元素;

2、元素位置改变

3、元素尺寸改变——边距、填充、边框、宽度和高度

4、内容改变——比如文本改变或者图片大小改变而引起的计算值宽度和高度改变;

5、页面渲染初始化

6、浏览器窗口尺寸改变——resize事件发生时;(所以需要函数节流)

3. 浏览器对回流和重绘做的优化工作

浏览器会维护1个队列,把所有会引起回流、重绘的操作放入这个队列,等队列中的操作到了一定的数量或者到了一定的时间间隔,浏览器就会释放队列,进行一个批处理。这样就会让多次的回流、重绘变成一次回流重绘。(有点类似文档碎片frameElement感觉)

虽然有了浏览器的优化,但有时候我们写的一些代码可能会强制浏览器提前释放队列,这样浏览器的优化可能就起不到作用了。当你请求向浏览器请求一些 style信息的时候,就会让浏览器释放队列,比如:

offsetTop, offsetLeft, offsetWidth, offsetHeightscrollTop/Left/Width/HeightclientTop/Left/Width/Heightwidth,height请求了getComputedStyle(), 或者 IE的 currentStyle

当你请求上面的一些属性的时候,浏览器为了给你最精确的值,需要释放队列,因为队列中可能会有影响到这些值的操作。即使你获取元素的布局和样式信息跟最近发生或改变的布局信息无关,浏览器都会强行刷新渲染队列。

4. 减少回流reflow和重绘repaint

(1) 不要一条一条修改DOM的样式

替换方法:

预先定义好css,然后修改DOM的className,修改style的style.cssText

(2) 把DOM离线后修改

先把DOM给display:none(有一次reflow),然后你想怎么改就怎么改。比如修改100次,然后再把他显示出来。clone一个DOM结点到内存里,然后想怎么改就怎么改,改完后,和在线的那个的交换一下。

(3) 不要把DOM结点的属性值放在一个循环里当成循环的变量。

(4) 尽可能修改层级比较低的DOM

(5) 为动画的HTML元素使用fixed或者absolute的position

修改他们的CSS是不会reflow的,因为使用fixed或者absolute的元素会脱离文档流

(6) 千万不要使用table布局

注意:CSS匹配DOM Tree主要是从右到左解析CSS的Selector,CSS匹配HTML元素是一个相当复杂和有性能问题的事情。DOM树要小,CSS尽量用id和class,千万不要过渡层叠下去。

欢迎关注。

    推荐阅读
  • 贾岛经典诗40首(大唐诗人贾岛经典五言诗作)

    题李凝幽居唐代:贾岛闲居少邻并,草径入荒园。寻隐者不遇唐代:贾岛松下问童子,言师采药去。剑客/述剑唐代:贾岛十年磨一剑,霜刃未曾试。忆江上吴处士唐代:贾岛闽国扬帆去,蟾蜍亏复圆。樵人归白屋,寒日下危峰。送无可上人唐代:贾岛圭峰霁色新,送此草堂人。麈尾同离寺,蛩鸣暂别亲。

  • 兴化方言小伙子怎么说(放屁用手揞wǎn)

    我们把一只手掌向上弯曲称为“碗”,把两只手掌并在一起向上弯曲也称为“碗”。用“放屁用手揞”形容这些弱智的措施虽有不雅之嫌,但却大有解气之妙。支书又重新物色了一位“李铁梅”,把女知青安排回南京过春节。兴化水田多,农人的许多农活都是在湴田的过程中完成的。湴河无疑是艰难的、危险的。对湴河的这种理解,在泰州人中是很普遍的。大队革委会给他戴了一顶破坏集体财产的帽子,要他接受群众的批判。

  • 半夜睡觉感觉抖是长个吗(为什么睡觉时身体会突然)

    当身体中的血钙低时,确实会导致肌肉、神经兴奋性亢进,从而引起痉挛抽搐。正确的睡姿可以有效减少临睡肌抽跃症的发生,一般情况下,多数人适宜以右侧卧位为宜。

  • 韩式酸菜怎么做(做泡菜的方法)

    韩式酸菜怎么做大白菜1.5kg、苹果个、梨1个、辣椒面150g、糯米粉50g、蒜50g、姜50g、盐50g。在盆内均匀的给白菜撒上盐,腌制12小时。苹果、梨去皮、去核,分别在榨汁机中打成汁备用。姜、蒜切末备用,小锅内倒入糯米粉。倒入苹果汁、梨汁,用中火熬成糊状。糯米糊放凉后,加入辣椒面、姜末、蒜末、搅拌均匀。腌好的白菜,挤去水分。将泡菜放入无油、无水的密封容器里,再放入冰箱,发酵3-5天即可。

  • 什么是什么什么什么的家(什么是什么什么什么的家举例)

    下面希望有你要的答案,我们一起来看看吧!什么是什么什么什么的家草丛是蟋蟀的家。大树是鸟儿的家。池塘是青蛙的家。大海是鲨鱼的家。森林是老虎的家。天空是星星的家。大地是小草的家。沙漠是骆驼的家。云朵是大雨的家。草原是羊儿的家。

  • 早上起床为什么水肿(早上起来水肿的原因)

    早上起床为什么水肿?我们一起去了解并探讨一下这个问题吧!建议患者可以到医院进行肾脏B超的检查,以及肾功能的相关检查可以明确诊断。第二种是由于心脏疾病引起来的,心脏疾病就会引起心功能不全,会导致心功能的心脏回血受限,引起患者体内血液淤积,从而导致局部出现水肿的现象,建议患者到医院检查,比如说心电图、心脏彩超、心肌酶谱等相关检查,如果发现是心脏疾病引起来的,建议及时进行相关治疗,避免引起严重的并发症。

  • 南京生育险最迟多久去办理 南京生育险多久可以拿到

    用人单位应当自用工之日起三十日内为其职工向社会保险经办机构申请办理社会保险登记。南京用人单位少报、漏报缴费基数怎么办拓展阅读:用人单位职工缴费基数如何确定?南京五项社会保险采用统一的缴费基数。职工当年度缴费基数为本人上一自然年度月平均工资收入。对职工工资收入超过缴费基数上限的,超过部分不计入缴费基数;对职工工资收入低于缴费基数下限的,按下限确定缴费基数。

  • 天猫超市怎么兑换超市卡(天猫超市卡怎么变现成现金)

    天猫超市卡/享淘卡有50面值,100面值,200面值,300面值,500面值,600面值,1000面值。因此我们在去购物的时候,都是有很多人在去进行使用的。但是现在我们的购物卡还有了另外的处理方式,我们可以将我们手上的购物卡去进行回收,京回收平台就是我们现在去进行回收平台,回收的速度快,价格还很高。

  • 承包方式一般有哪三种(承包方式都有哪三种介绍)

    工程总承包的具体方式、工作内容和责任等,由业主与工程总承包企业在合同中约定。对于一些工程较大的项目,发包人可能分别与几个勘察人、设计人、施工人分别签订若干份独立的勘察合同、设计合同、施工合同,各承包人各自独立完成承包工作。联合承包《建筑法》第二十七条第一款规定:“大型建筑工程或者结构复杂的建筑工程,可以由两个以上的承包单位联合共同承包。共同承包的各方对承包合同的履行承担连带责任。”

  • 摇到的车牌可以过户给家里人吗(摇不到号把奥迪车挂在别人名下)

    今年4月9日,两人完成了过户手续,就这样,车某做了陈某的专职驾驶员。接警后,余杭区公安分局临平刑侦中队多方调查取证,经过半个月的侦查,将车某、江某和何某3人抓获。因涉嫌诈骗罪,3人均被余杭警方依法刑事拘留,案件还在进一步侦办当中。至于陈某的那辆奥迪A6L,警方表示,因为买车人是通过二手车市场正常购得,并且对车某等人的诈骗行为并不知情,属于善意取得,无法追回。