资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

JavaScript中怎么提升DOM的运行速度

JavaScript中怎么提升DOM的运行速度,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

成都创新互联服务项目包括射洪网站建设、射洪网站制作、射洪网页制作以及射洪网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,射洪网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到射洪省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

我们都知道,DOM操作的效率是很低的,而且不是一般的慢,而且这也是引发性能问题的常见问题之一。为什么会慢呢?因为对DOM的修改为影响网页的用户界面,重绘页面是一项昂贵的操作。太多的DOM操作会导致一系列的重绘操作,为了确保执行结果的准确性,所有的修改操作是按顺序同步执行的。我们称这个过程叫做回流(reflow),同时这也是最昂贵的浏览器操作之一。回流操作主要会发生在几种情况下:

◆当对DOM节点执行新增或者删除操作时。

◆动态设置一个样式时(比如element.style.width="10px")。

◆当获取一个必须经过计算的尺寸值时,比如访问offsetWidth、clientHeight或者其他需要经过计算的CSS值(在兼容DOM的浏览器中,可以通过getComputedStyle函数获取;在IE中,可以通过currentStyle属性获取)。
解决问题的关键,就是限制通过DOM操作所引发回流的次数。大部分浏览器都不会在JavaScript的执行过程中更新DOM。相应的,这些浏览器将对对DOM的操作放进一个队列,并在JavaScript脚本执行完毕以后按顺序一次执行完毕。也就是说,在JavaScript执行的过程中,用户不能和浏览器进行互动,直到一个回流操作被执行。( 失控脚本对话框 会触发回流操作,因为他执行了一个中止JavaScript执行的操作,此时会对用户界面进行更新)

如果要减少由于DOM修改带来的回流操作,有两个基本的方法。***个就是在对当前DOM进行操作之前,尽可能多的做一些准备工作。一个经典的例子就是向document对象中添加很多DOM节点:

for (var i=0; i < items.length; i++){      var item = document.createElement("li");      item.appendChild(document.createTextNode("Option " + i);      list.appendChild(item);  }

这段代码的效率是很低的,因为他在每次循环中都会修改当前DOM结构。为了提高性能,我们需要将这个次数降到***,对于这个案例来说,***的办法是建立一个文档碎片(document fragment),作为那些已创建元素元素的临时容器,***一次将容器的内容直接添加到父节点中:

var fragment = document.createDocumentFragment();  for (var i=0; i < items.length; i++){      var item = document.createElement("li");      item.appendChild(document.createTextNode("Option " + i);      fragment.appendChild(item);  }  list.appendChild(fragment);

经过调整的代码,只会修改一次当前DOM的结构,就在***一行,而在这之前,我们用文档碎片来保存那些中间结果。因为文档碎片没有任何可见内容,所以这类修改不会触发回流操作。实际上,文档碎片也不能被添加到DOM中,我们需要将它作为参数传给appendChild函数,而实际上添加的不是文档碎片本身,而是它下面的所有子元素。

看完上述内容,你们掌握JavaScript中怎么提升DOM的运行速度的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


分享题目:JavaScript中怎么提升DOM的运行速度
标题URL:http://cdkjz.cn/article/jhgdii.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220