zoukankan      html  css  js  c++  java
  • JavaScript DOM基础总结

    上个月在进行百度三面时候,面试官提问JavaScript DOM方法,我回答的有点少,前面太关注JavaScript 兼容性,框架方面,JavaScript 原生DOM基础没有记牢,心中有点遗憾。下来继续看我喜欢的红宝书,希望深入学习JavaScript DOM。

    DOM(文档对象模型)是针对HTML和XML文档的一个API,描绘了一个层次化的节点树,允许开发人员添加、删除和修改页面的某一部分。

    1.Node方面

    1.1 节点类型

    节点类型(nodeName) 数值常量(nodeValue)
    元素节点 1
    属性节点 2
    文本节点 3
    注释节点 8
    文档节点 9
    文档碎片节点 11

    确定节点类型,兼容的方法是将nodeType属性与数字值进行比较,如下所示:

    if(someNode.nodeType==1){
    alert("Node is an element");
    }
    

    1.2 节点关系

    每一个节点都有一个childNodes属性,其中保存着一个NodeList对象。NodeList是一种类数组对象,用于保存一组有序的节点,可以通过位置来访问这些节点。

    1.3 节点操作

    注意事项

    a. 注意appendChild的用法:

    1.添加功能:像childNodes列表的末尾添加一个节点,添加节点后,childNodes的新增节点,父节点以及以前的最后一个子节点的关系指针都会得到相应更新。

    
    var returnedNode=someNode.appendChild(newNode);
    alert(returnedNode==newNode)//true
    
    

    2.移位功能:如果传入到appendChild()中的节点已经是文档的一部分,那么结果就是将该节点从原来的位置转移到新的位置。

    
    var returnedNode=someNode.appendChild(someNode.firstChild);
    alert(returnedNode==someNode.firstChild)//false
    alert(returnedNode==someNode.lastChild)//true
    
    

    3.与insertBefore区别:后者是把节点放在childNodes某个特定的位置上,而不是放在末尾,该方法有两个参数:要插入的节点和作为参照点的节点。

    //输入后成为最后一个子节点
    var returnedNode=someNode.insertBefore(newNode,null);
    alert(returnedNode==someNode.lastChild)//true
    
    //输入后成为第一个子节点
    var returnedNode=someNode.insertBefore(newNode,firstChild);
    alert(returnedNode==someNode.firstChild)//true
    

    b. 注意replaceChlid用法

    前面的appendChild和insertBefore都是插入节点,不会移除节点。而replace方法接受2个参数:要插入的节点和要替换的节点,要替换的节点将会从文档中被移除,同时由要插入的节点占据其位置。从技术上讲:被替换的节点还在文档中,但是没有位置。

    c. 注意cloneChild用法

    cloneChild方法接受一个布尔值参数,表示是否执行深复制。

    • true:深复制,复制节点及其整个子节点树。
    • false:浅复制,只复制节点本身。、


    二、Document类型

    Document类型可以表示HTML页面或者其他基于xml的文档。作为HTMLDocument的一个实例,document对象还有一些标准的Document对象所没有的属性,例如和网页请求有关的3个属性是:URL,domain,referrer,应用最多的是在查找元素方面:


    三、Element类型

    该类型提供了对元素标签名,子节点及特性的访问。所有的HTML元素都是由HTMLElement类型表示,HTMLElement类型直接继承自element并添加了一些属性:id,title,lang,dir,className.

    注意事项

    1.对id或lang的修改对用户而言是透明不可见的(假设没有基于透明的值设置的css样式)
    2.title的修改只会体现在鼠标移动到这个元素上时会显示出来。
    3.对dir的修改只会体现在属性被重写的那一刻,立刻影响页面中文本的左右对齐方式。
    4.修改className时,如果新类型关联了与此前不同的css样式,那么就会立刻应用新的样式。


    四、Attr类型


    五、Text类型

    六、DOM扩展

    1.Selectors API扩展:querySelector()方法和querySelectorAll()方法
    注意事项
    querySelector只返回匹配的第一个元素,如果没有匹配项,返回null。

    querySelectorAll返回匹配的元素集合,如果没有匹配项,返回空的nodelist(节点数组)。 并且返回的结果是静态的,之后对document结构的改变不会影响到之前取到的结果。
    目前IE8+,ff,chrome都支持此api(IE8中的selector string只支持css2.1的)。

    关于两者的详细区别,我前面一篇博客写过:http://www.cnblogs.com/QingFlye/p/4006484.html

    2.HTML5扩展:新增getElementByClassName方法

    总结

    DOM操作往往是JavaScript程序中开销最大的部分,访问nodeList导致的问题最多。NodeList对象都是动态的,意味着每次访问该对象,都会进行一次查询,有鉴于此,最好的办法是:减少DOM操作。
    关于前端性能优化问题,比较耳熟能详的是Yahoo14条军规与前端性能优化:http://www.cnblogs.com/QingFlye/p/3891980.html
    关于DOM兼容性问题,前面也总结过一篇博客(http://www.cnblogs.com/QingFlye/p/4302099.html)
    在知乎里也分享过:http://www.zhihu.com/question/29072028/answer/43095799

  • 相关阅读:
    zepto源码解读(二)——zpeto.init()——(4)$.each()函数 / likeArray函数
    zepto源码解读(二)——zpeto.init()——(3)isFunction函数
    JS小问题之—— 关于SetCapture() 和 ReleaseCapture()的用法
    zepto源码解读(二)——zpeto.init()函数——(2)zepto.fragment()函数详解
    zepto源码解读(二)——zpeto.init()函数——(1)结构整理
    JS小问题之——缓冲运动
    zepto源码解读(一)——整体架构
    jquery源码猜想(一)
    去除小括号和小括号里面的内容
    查看端口使用情况
  • 原文地址:https://www.cnblogs.com/QingFlye/p/4389724.html
Copyright © 2011-2022 走看看