《高性能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编程篇的更多相关文章

  1. 《高性能javascript》 领悟随笔之-------DOM编程篇(二)

    <高性能javascript> 领悟随笔之-------DOM编程篇二 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

  2. JavaScript(三)-- DOM编程

    JavaScript编程中最基本的就是DOM编程,DOM是 Document Object Model文本对象模型,就是对DOM对象进行编程的过程. Java语言和Js都有针对于DOM的编程,两者类似 ...

  3. 轻松学习JavaScript十八:DOM编程学习之DOM简单介绍

    一DOM概述 DOM(文档对象模型)是HTML和XML的应用程序接口(API).DOM将把整个页面规划成由节点层级构成的文档. DOM描绘了一个层次化的节点树,执行开发者加入,移除和改动页面的某一部分 ...

  4. 轻松学习JavaScript二十七:DOM编程学习之事件模型

    在介绍事件模型之前,我们先来看什么是事件和什么是event对象. 一事件介绍 JavaScript事件是由訪问Web页面的用户引起的一系列操作,使我们有能力创建动态页面.事件是能够被 JavaScri ...

  5. 《高性能javascript》随笔

    1.css文件在head标签中引入,保证在渲染结构的时候进行样式渲染2.Js文件放在body的底部,确保在渲染dom树的时候不会出现js阻塞3.函数内的变量是访问速度最快的,全局变量的访问速度是最慢的 ...

  6. javascript性能优化之Dom编程性能调优总结

    1.最小化的Dom访问,在一次Dom访问做尽可能多的操作: 2.使用局部变量存放指向反复访问的元素节点的Dom引用,原则上js代码中不应该重复获取同一个元素节点,除非它在运行过程中发生改变: 3.对元 ...

  7. 高性能JavaScript DOM编程

    我们知道,DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价很昂贵.有个贴切的比喻,把DOM和JavaScript(这里指ECMScript)各自想象为一个岛屿,它们之间用 ...

  8. 高性能JavaScript笔记一(加载和执行、数据访问、DOM编程)

    写在前面 好的书,可能你第一遍并不能领会里面的精魂,当再次细细品评的时候,发现领悟的又是一层新的含义 (这段时间,工作上也不会像从前一样做起来毫不费力,开始有了新的挑战,现在的老大让我既佩服又嫉妒,但 ...

  9. 高性能JavaScript之DOM编程

    我们知道.DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价非常昂贵. 有个贴切的比喻.把DOM和JavaScript(这里指ECMScript)各自想象为一个岛屿,它们之 ...

随机推荐

  1. 手动添加kdump

    背景:     Linux嵌入式设备内核挂死后,无法自动重启,需要手动重启.而且如果当时没有连串口的话,就无法记录内核挂死时的堆栈,所以需要添加一种方式来记录内核挂死信息方便以后调试使用.设备中增加k ...

  2. 港真,到底应该选择OA还是BPM?

    越来越多企业意识到流程管理的重要性,但是,选择OA还是BPM,却让他们产生了选择困难症. 一方面,企业皆注重流程的高效运转,最好内外部的业务都能用一个系统来解决.所有流程一天就能上线什么的,那就更好啦 ...

  3. Android—应用程序开机自启

    android开机时候会发送开机广播,我们想要收到广播知道手机开机,才能启动我们的应用程序. 首先要在配置文件中添加相应权限: <uses-permission android:name=&qu ...

  4. Android事件分发机制浅谈(一)

    ---恢复内容开始--- 一.是什么 我们首先要了解什么是事件分发,通俗的讲就是,当一个触摸事件发生的时候,从一个窗口到一个视图,再到一个视图,直至被消费的过程. 二.做什么 在深入学习android ...

  5. ionic第一坑——ion-slide-box坑(ion-slide分两页的坑)

    ionic.views.Slider = ionic.views.View.inherit({ initialize: function (options) { . . . function setu ...

  6. POJ3693 Maximum repetition substring [后缀数组 ST表]

    Maximum repetition substring Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9458   Acc ...

  7. Struts框架的核心业务

    Struts的核心业务 Struts核心业务有很多,这里主要介绍了比较简单一些的: 请求数据的处理,和数据自动封装,类型自动转换 1.Struts中数据处理 1.1.方式1:直接过去servletap ...

  8. Unity插件之plyGame教程:DiaQ对话系统

    本文为孤月蓝风编写,转载请注明出处:http://fengyu.name/?cat=game&id=296 DiaQ是plyGame旗下的一款对话及任务系统.拥有可视化的对话及任务编辑器,能够 ...

  9. 实现ABP中Person类的权限功能

    菜单项的显示功能已经完全OK了.那么我们就开始制作视图功能吧. 首先测试接口是否正常 我们通过代码生成器将权限和application中大部分功能已经实现了.那么我们来测试下这些接口ok不. 浏览/a ...

  10. Atitit osi tcp ip 对应attilax总结

    Atitit osi tcp ip 对应attilax总结 Atitit 网络摄像机又叫IP CAMERA(简称IPC)常见的协议组合 网络摄像机又叫IP CAMERA(简称IPC)由网络编码模块和模 ...