《高性能javascript》 领悟随笔之-------DOM编程篇
《高性能javascript》 领悟随笔之-------DOM编程篇一
序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整个页面文档。DOM编程性能一直以来都是非常受开发者关注的话题,如何编写高性能的DOM是前端开发必不可少的技能。
1.DOM访问与修改
访问DOM元素是有一定的性能代价的,有时候这种代价会整体拖慢网页的运行速度,例如循环访问或修改一些元素内容,操作不当会导致页面卡帧,甚至是假死,例如下面的代码。
function loop(){
for(var i=0;i<1000;i++){
document.getElementById("id").innerHTML += "a";
}
}
loop()函数 循环修改某个元素的innerHTML内容,这段代码的问题在于,每次循环,这个元素都会被访问两次 一次读取,一次修改;
优化的关键在于,我们可以将需要的最终内容拼接成一个字符串,在字符串拼接完成之后一次性修改,这样做大大提升了整体运行速度,并且使代码更容易被理解;
function loop(){
var oDiv = document.getElementById("id"),
sDIV = oDiv.innerHTML;
for(var i=0;i<1000;i++){
sDIV += "a"; //拼接文本字符串
}
oDiv.innerHTML = sDiv;
}
同理,当我们需要请求某一个表格,异步插入数据的时候,往往先将数据拼接成字符串,再利用innerHTML一次性插入;
for(...){
var t += "<div>......</div>";
}
table.innerHTML = ......;
总结:访问DOM的次数越多,代码的运行速度越慢。因此,通常的经验法则是:减少dom的访问次数,把运算尽量用ECMASCRIPT处理;
2.访问html集合
HTML集合是包含了一组节点信息的类数组对象,它拥有数组的下标访问特性,又不同于数组的引用;
列举一些返回html集合的方法:
document.getElementsByTagName();
document.getElementsByClassName();
document.images //返回页面中所有的img元素
document.links //返回页面中的所有链接元素(a)
document.forms //返回页面中所有的表单
......
在访问或者修改这些元素集合的时候,因为访问元素集合始终是没有访问数组快的,所以在修改元素变化不大而的时候,可以将其复制到另一个数组中,从而提升访问速度
function htmltoArray(h){
for(var i=0,len=h.length,arr=[];i<len;i++){ //遍历 复制整个集合
arr[i]=h[i];
}
return arr;
}
这是一个有趣的方法,笔者通过这个函数,试着做了一个类似与jquery的 .index() 方法 , 其原理是将集合复制到数组中 利用数组对象的方法indexof() 确定某个元素相对它的父级元素的位置,代码如下:
function Index(a){
var b = htmltoArray(a.parentNode.children);
return b.indexOf(a); //确定a元素相对它的父级元素b的位置
}
另外,对于所有的DOM访问,多次访问同一个元素的时候,需要把它存在一个局部变量中,减少重复访问的次数;
总结:所有的需要多次访问的元素,事先将其保存在一个局部变量中可以减少访问次数,提高性能,遍历一个数组总是要比遍历一个集合要快得多,一些新的api能够更快速的获得html集合,比如querySeleteor()querySeleteorAll(),使dom集合操作更加简单,高效; api参考地址:http://www.cnblogs.com/daxian2012/archive/2012/10/18/2729359.html
《高性能javascript》 领悟随笔之-------DOM编程篇的更多相关文章
- 《高性能javascript》 领悟随笔之-------DOM编程篇(二)
<高性能javascript> 领悟随笔之-------DOM编程篇二 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...
- JavaScript(三)-- DOM编程
JavaScript编程中最基本的就是DOM编程,DOM是 Document Object Model文本对象模型,就是对DOM对象进行编程的过程. Java语言和Js都有针对于DOM的编程,两者类似 ...
- 轻松学习JavaScript十八:DOM编程学习之DOM简单介绍
一DOM概述 DOM(文档对象模型)是HTML和XML的应用程序接口(API).DOM将把整个页面规划成由节点层级构成的文档. DOM描绘了一个层次化的节点树,执行开发者加入,移除和改动页面的某一部分 ...
- 轻松学习JavaScript二十七:DOM编程学习之事件模型
在介绍事件模型之前,我们先来看什么是事件和什么是event对象. 一事件介绍 JavaScript事件是由訪问Web页面的用户引起的一系列操作,使我们有能力创建动态页面.事件是能够被 JavaScri ...
- 《高性能javascript》随笔
1.css文件在head标签中引入,保证在渲染结构的时候进行样式渲染2.Js文件放在body的底部,确保在渲染dom树的时候不会出现js阻塞3.函数内的变量是访问速度最快的,全局变量的访问速度是最慢的 ...
- javascript性能优化之Dom编程性能调优总结
1.最小化的Dom访问,在一次Dom访问做尽可能多的操作: 2.使用局部变量存放指向反复访问的元素节点的Dom引用,原则上js代码中不应该重复获取同一个元素节点,除非它在运行过程中发生改变: 3.对元 ...
- 高性能JavaScript DOM编程
我们知道,DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价很昂贵.有个贴切的比喻,把DOM和JavaScript(这里指ECMScript)各自想象为一个岛屿,它们之间用 ...
- 高性能JavaScript笔记一(加载和执行、数据访问、DOM编程)
写在前面 好的书,可能你第一遍并不能领会里面的精魂,当再次细细品评的时候,发现领悟的又是一层新的含义 (这段时间,工作上也不会像从前一样做起来毫不费力,开始有了新的挑战,现在的老大让我既佩服又嫉妒,但 ...
- 高性能JavaScript之DOM编程
我们知道.DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价非常昂贵. 有个贴切的比喻.把DOM和JavaScript(这里指ECMScript)各自想象为一个岛屿,它们之 ...
随机推荐
- 手动添加kdump
背景: Linux嵌入式设备内核挂死后,无法自动重启,需要手动重启.而且如果当时没有连串口的话,就无法记录内核挂死时的堆栈,所以需要添加一种方式来记录内核挂死信息方便以后调试使用.设备中增加k ...
- 港真,到底应该选择OA还是BPM?
越来越多企业意识到流程管理的重要性,但是,选择OA还是BPM,却让他们产生了选择困难症. 一方面,企业皆注重流程的高效运转,最好内外部的业务都能用一个系统来解决.所有流程一天就能上线什么的,那就更好啦 ...
- Android—应用程序开机自启
android开机时候会发送开机广播,我们想要收到广播知道手机开机,才能启动我们的应用程序. 首先要在配置文件中添加相应权限: <uses-permission android:name=&qu ...
- Android事件分发机制浅谈(一)
---恢复内容开始--- 一.是什么 我们首先要了解什么是事件分发,通俗的讲就是,当一个触摸事件发生的时候,从一个窗口到一个视图,再到一个视图,直至被消费的过程. 二.做什么 在深入学习android ...
- ionic第一坑——ion-slide-box坑(ion-slide分两页的坑)
ionic.views.Slider = ionic.views.View.inherit({ initialize: function (options) { . . . function setu ...
- POJ3693 Maximum repetition substring [后缀数组 ST表]
Maximum repetition substring Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9458 Acc ...
- Struts框架的核心业务
Struts的核心业务 Struts核心业务有很多,这里主要介绍了比较简单一些的: 请求数据的处理,和数据自动封装,类型自动转换 1.Struts中数据处理 1.1.方式1:直接过去servletap ...
- Unity插件之plyGame教程:DiaQ对话系统
本文为孤月蓝风编写,转载请注明出处:http://fengyu.name/?cat=game&id=296 DiaQ是plyGame旗下的一款对话及任务系统.拥有可视化的对话及任务编辑器,能够 ...
- 实现ABP中Person类的权限功能
菜单项的显示功能已经完全OK了.那么我们就开始制作视图功能吧. 首先测试接口是否正常 我们通过代码生成器将权限和application中大部分功能已经实现了.那么我们来测试下这些接口ok不. 浏览/a ...
- Atitit osi tcp ip 对应attilax总结
Atitit osi tcp ip 对应attilax总结 Atitit 网络摄像机又叫IP CAMERA(简称IPC)常见的协议组合 网络摄像机又叫IP CAMERA(简称IPC)由网络编码模块和模 ...