js常用DOM操作

在博客园看到了苏夏写的常用DOM整理文章,地址:http://www.cnblogs.com/cabbagen/p/4579412.html,然后抽时间都试了一下这些常用的DOM操作。在这里记录一下。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>常用dom</title>
 6     <script>
 7         window.onload = function(){
 8             function $(id){ //获取id元素
 9                 return typeof id === 'string' ? document.getElementById(id) : id;
10             }
11             //取得节点
12             var box = $('box'); //得到id名为box的元素节点
13             var div = document.getElementsByTagName('div'); //得到所有标签为div的元素节点集合
14             var name = document.getElementsByName('our'); //得到name为our的元素
15             //var cls = document.getElementsByClassName('box'); //ie8及以下不支持
16             //var clsdiv = document.querySelectorAll('#box,#boxs'); //找到所有id为box和boxs的元素数组集合querySelector只能找到第一个,ie8以上才支持
17 
18 
19             //遍历节点
20             var ul = $('ul');
21             var lis = ul.children; //取得ul下的直系子元素li
22             var lis1 = getFirst(ul); //在火狐下它返回指定元素的子元素集合,包括HTML节点,所有属性,文本。只有当nodeType==1时才是元素节点,2是属性节点,3是文本节点。
23             function getFirst(ele){ //通过childNodes封装得到第一个子元素
24                 for(var i=0;i<ele.childNodes.length;i++){
25                     if(ele.childNodes[i].nodeType == 1){
26                         return ele.childNodes[i];
27                     }
28                 }
29             };
30             var lisFirst = firstChild(ul);  //也可以这样获取到第一个子元素,比较方便
31             var lisLast = lastChild(ul); //也可以这样获取到最后一个子元素,比较方便
32             function firstChild(node){ //封装得到第一个子元素
33                 return node.firstElementChild || node.firstChild; 
34             };
35             function lastChild(node){ //封装得到最后一个子元素
36                 return node.lastElementChild || node.lastChild; 
37             };
38             function prev(node){ //得到上一个元素
39                 return node.previousElementSibling || node.previousSibling; 
40             };
41             function next(node){ //得到下一个元素
42                 return node.nextElementSibling || node.nextSibling; 
43             };
44             var parent = $('con').parentNode; //得到id为con的元素的父节点也就是得到了id为box的元素节点
45 
46 
47             //获取节点信息
48             var nodeName = $('box').nodeName; //获取元素或者属性节点的标签名称 结果是:DIV 
49             var nodeValue = $('con').childNodes[0].nodeValue; //获取文本节点的内容 结果是:文本节点内容
50             var innerHTML = $('inner').innerHTML; //获取并设置元素节点的内容 结果是:文本节点内容<span>123</span> 可能会包含HTML标签
51             var innerText = innerText($('inner')); //获取并设置元素节点的纯文本内容不包含标签结果是:文本节点内容123 (ie用innerText,ff用textContent)
52             function innerText(node){
53                 return node.textContent || node.innerText;
54             };
55             for(var i=0;i<lis.length;i++){
56                 var index = lis[i].getAttribute('index'); //获取属性节点的值
57                 lis[i].setAttribute('index', i); //设置属性节点的值
58             };
59             var nodeType = $('ul').attributes[0].nodeType; //获取节点的类型 元素节点: 1;属性节点: 2;文本节点: 3;文档节点: 9;注释节点: 8;
60 
61 
62             //操作节点
63             var input = document.createElement('input'); //创建元素节点
64             var textNode = document.createTextNode('你们好'); //创建文本节点
65             var attrNode = document.createAttribute('index'); //创建属性节点
66             attrNode.value = '123';
67             $('box').setAttributeNode(attrNode);
68             //$('box').remove(); //删除节点 在ie中 .removeNode(true)
69             $('ul').removeChild($('ul').children[0]);
70             document.body.appendChild(textNode); //插入节点
71             var clone = $('con').cloneNode([true]); //克隆节点 传入true为深度复制,会把内容也复制过来
72             document.body.appendChild(clone);
73             $('box').replaceChild(input, $('con')); //替换节点
74             function addClass(element,className) { //添加class
75                  element.className += className;
76             };
77             function removeClass(element,removeClassName) { //移除class
78                  var classStr = element.className;
79                  element.className = classStr.replace(removeClassName,'').split(/s+/).join(' ').replace(/^s+/,'').replace(/s+$/,'');
80             }  
81             addClass($('box'), ' haha ei');
82             removeClass($('box'), 'haha');
83         }
84     </script>
85 </head>
86 <body>
87     <div id="box" class="box wo" name="our">
88         <div id="con">文本节点内容</div>
89     </div>
90     <div id="boxs" class="box" name="our"></div>
91     <div id="inner">文本节点内容<span>123</span></div>
92     <ul id="ul">
93         <li index="0"></li>
94         <li index="1"></li>
95         <li index="2"></li>
96     </ul>
97 </body>
98 </html>
原文地址:https://www.cnblogs.com/dibaosong/p/4588161.html