1元素属性

 

1.1childNodes


返回元素的一个子节点的数组

(不推荐,建议用非标准children代替)
提醒:只包含一级子节点,不包含后辈孙级别以下节点。

children:返回元素的一个子节点的数组(同childNodes区别,只返回Element(元素) 类型节点,不返回 Text 节点)


1.2nodeType

返回节点类型

1.3attributes

返回节点属性

<!DOCTYPE html>
<HTML LANG="en">

<HEAD>
  <META CHARSET="UTF-8">
  <TITLE>Document</TITLE>
</HEAD>
<BODY>
  <UL ID="uid" STYLE="border:1px solid black">
    <LI>1111</LI>
    <LI>2222</LI>
    <LI>3333</LI>
    <LI>4444</LI>
  </UL>
  <script type="text/javascript">
    var uid =  document.getElementById('uid');

    /*
     *只读属性:childNodes:
     *返回元素的一个子节点的数组
     */
    for (var i = 0; i < uid.childNodes.length; i++) {
      /*只读属性:
       * [element.nodeType]
       * @有12种不同的节点类型,不同的节点类型也可以有不同的子节点类型: 
       * @Node常用类型 :
       * 1 ELEMENT_NODE
       * 2 ATTRIBUTE_NODE
       * 3 TEXT_NODE
       */
       if (uid.childNodes[i].nodeType=="1") {
        uid.childNodes[i].style.background ='red';
       }

      }

    //只读属性:attributes  数组
    document.write("attributes:"+uid.attributes.length);
    document.write("<br>");
    document.write("attributes:"+uid.attributes[1]);
    document.write("<br>");
    document.write("[attributes.name]:"+uid.attributes[1].name+",[attributes.value]:"+uid.attributes[1].value);
  </script>
</BODY>
</HTML> 
 
如果这里使用chilren,就不需要判断uid.childNodes[i].nodeType=="1"
如下图:

1.4firstChild

返回元素的第一个子节点

标准下,会包含文本节点(IE9)
非标准下,只包含元素节点(IE8及以下)
 

1.5firstElementChild

 
标准下,获取元素类型的子节点
//这样非标准和标准的情况下都会选择第一个元素节点
var oFirst =uid.firstElementChild||uid.firstChild; 
其实最好的写法应该是
oFirst = uid.children[0]; 

这样都可以获取元素第一个子节点。
 

1.6lastChild

返回的最后一个子元素

和firstChild差不多

var oLast = uid.lastElementChild||uid.lastChild; 
 

1.7nextSibling

返回该元素紧跟的一个元素

nextElementSibling
标准下,返回该元素紧跟的一个元素
      /*
      下一个兄弟节点
       */
      var oNext = uid.nextElementSibling||uid.nextSibling;

1.8previousSibling

返回某个元素紧接之前元素

previousElementSibling
      /*
      上一个兄弟节点
       */
      var oPrev = uid.previousElementSibling||uid.previousSibling; 
 

1.9parentNode

返回父级节点

<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <script type="text/javascript">
    window.onload=function () {
      var uid =  document.getElementById('uid');
      var aA =  document.getElementsByTagName('a');
      for (var i = 0; i < aA.length; i++) {
        aA[i].onclick = function (){
        /**
         * 元素.parentNode:当前节点的父节点
         */
         this.parentNode.style.display='none';
        }
      }
    }
  </script>
</head>
<body>
  <ul id="uid" style="border:1px solid black">
    <li>
      1111
      <a href="javascript:;">隐藏</a>
    </li>
    <li>
      2222
      <a href="javascript:;">隐藏</a>
    </li>
  </ul>

</body>
</html> 
 
点击隐藏,<li style="display: none;">
 

1.10offsetParent

返回元素的偏移容器(离当前元素最近的,有定位的父节点)
如果没有postion定位,返回 body
 
  <style type="text/css">
    div{ padding: 40px 50px; }
    #div1 {background: red;position: relative;}
    #div2{background: blue;}
    #div3 {background: orange}
  </style>
  <script type="text/javascript">
    window.onload=function () {
      var oDiv3 =  document.getElementById('div3');
     console.log(oDiv3.parentNode.id); //div2
     
     /**
      * 元素.offsetParent:离当前元素
      * (最近的一个有定位)的父节点
      */
     console.log(oDiv3.offsetParent.id);
     //#div1有position的css样式,所以这个时候结果:div1
     //如果都没有position样式,那结果:body1
    }
  </script></head>
  <body id="body1">
    <div id='div1'>
      <div id="div2">
        <div id="div3"></div>
      </div>
    </div>
  </body>

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
window.onload=function () {
            var oDiv3 =  document.getElementById('div3');
 
            var p = getPos(oDiv3);
 
            console.log(p)
            //alert(p.left) //108
        }
         
        //封装绝对位置getPos
        function getPos(obj) {
            var pos={left:0,top:0};
            while(obj)  {
                pos.left +=obj.offsetLeft;
                pos.top +=obj.offsetTop;
                obj=obj.offsetParent;
            }
            return pos;
        }

1.11offsetLeft、offsetTop

 offsetLeft

返回当前元素的相对水平偏移位置的偏移容器
当前元素到定位父级的距离(偏移值)
到当前元素到offsetParent的距离
offsetTop
返回当前元素的相对垂直偏移位置的偏移容器
 
  <style type="text/css">
    div{ padding: 40px 50px; }
    #div1 {background: red;position: relative;}
    #div2{background: blue;}
    #div3 {background: orange;position: relative;}
  </style>
  <script type="text/javascript">
    window.onload=function () {
      var oDiv3 =  document.getElementById('div3');
      /**
       * offsetLeft[Top]:当前元素到定位父级的距离(偏移值)、
       * 到当前元素到offsetParent的距离
       */
      console.info("oDiv3.offsetParent.id:"+oDiv3.offsetParent.id+",offsetLeft:"+oDiv3.offsetLeft+",offsetTop:"+oDiv3.offsetTop);
      //[oDiv3.offsetParent.id]:div1,[offsetLeft]:100,[offsetTop]:80
    }
  </script></head>
  <body id="body1">
    <div id='div1'>
      <div id="div2">
        <div id="div3"></div>
      </div>
    </div>
  </body> 

 
 

1.12clientWidth、offsetWidth

offsetWidth
返回元素的宽度,包括边框和填充,但不是边距
(样式宽 + padding + border)
clientWidth
在页面上返回内容的可视宽度(不包括边框,边距或滚动条)
(样式宽 + padding)
  <script type="text/javascript">
  window.onload =function(){
    var divv = document.getElementById("divv");
    
    /**
     * style.width 样式宽
     * clientWidth(可视宽):样式宽 + padding
     * offsetWidth(占位宽):样式宽 + padding + border
     */
    console.log(divv.style.width) //100px
    console.log(divv.clientWidth) //120
    console.log(divv.offsetWidth) //122
  }

</script>
</head>
<body>
  <div id="divv" style="width: 100px;height: 100px;
  border: 1px solid red;
  padding: 10px;margin: 10px;"></div>
</body> 

 
 

2元素的操作(创建、插入、删除、替换)

2.1创建DOM元素

createElement(标签名) 创建一个节点
appendChild(节点) 追加一个节点
  var btn=document.createElement("BUTTON");
  var t=document.createTextNode("CLICK ME");
  btn.appendChild(t);
  document.body.appendChild(btn); 

 

2.2插入元素

insertBefore(节点, 原有节点) 在已有元素前插入
<!DOCTYPE html>
<html>
<body>

<ul id="myList1"><li>Coffee</li><li>Tea</li></ul>
<ul id="myList2"><li>Water</li><li>Milk</li></ul>

<p id="demo">Click the button to move an item from one list to another</p>

<button onclick="myFunction()">Try it</button>

<script>
function myFunction()
{
var node=document.getElementById("myList2").lastChild;
var list=document.getElementById("myList1");
list.insertBefore(node,list.childNodes[0]);
}
</script>

</body>
</html> 

 

2.3删除DOM元素

removeChild(节点) 删除一个节点
例子:删除留言
 

2.4替换DOM元素

replaceChild(节点, 已有节点) 替换节点

 
例子:留言板插入内容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script type="text/javascript">
        window.onload=  function () {
            var oText = getId('text1');
            var oBtn =getId('btn');
            var oUl = getId('ul1');
 
            oBtn.onclick = function () {
                var oLi =  document.createElement('li');
                 oLi.innerHTML = oText.value;
                 /*
                  *  删除
                  */
                 var oA =  document.createElement('a');
                 oA.innerHTML = '删除';
                 oA.href = 'javascript:;';
                 oA.onclick =function(){
                    /**
                     * 父级.removeChild(要删除的元素)
                     */
                    oUl.removeChild(this.parentNode);
                 }
                 oLi.appendChild(oA);
                 /*
                  *  替换
                  */
                 var oAreplce =  document.createElement('a');
                 var textnode= document.createTextNode("11111111111");
                 oAreplce.innerHTML = '替换';
                 oAreplce.href = 'javascript:;';
                 oAreplce.onclick =function(){
                    /**
                     * 父级.removeChild(要删除的元素)
                     */
                    this.parentNode.replaceChild(textnode, this);
                 }
                 oLi.appendChild(oAreplce);
                  
 
                /**
                 *  父级.appendChild(要添加的元素) 追加子元素
                 */
                //oUl.appendChild(oLi);
 
                /**
                 * 父级.insertBefore(新的元素,被插入的元素)  在指定的元素前面插入新元素
                 * 在IE下如果第二个参数节点不存在,会报错
                 * 其他浏览器如果第二个参数不存在,则会以appendChild替代
                 */
                 if (oUl.children[0]) {
                    oUl.insertBefore(oLi,oUl.children[0]);
                 }
                 else{
                    oUl.appendChild(oLi);
                 }
                }
 
 
                function getId(id) {
                    var dw = document.getElementById(id);
                    return dw;
                }
            }
 
 
        </script>
    </head>
    <body>
        <input type="text" id='text1'/><input type="button" value="留言" id="btn"/>
        <ul id="ul1"></ul>
    </body>
    </html>

 

 
 
 

JS中级 - 01:DOM节点的更多相关文章

  1. 原生js快速渲染dom节点

    function renderDom(str){ var _div = document.createElement('div'); _div.innerHTML = str; var dom_tem ...

  2. JS学习之DOM节点的关系属性封装、克隆节点、Dom中Style常用的一些属性等小结

    JS DOM节点: 在JS DOM中节点的关系被定义为节点的属性: 通常有以下几种节点之间的关系: (这里的关系是所有浏览器都支持的) parentNode    父节点 childNodes     ...

  3. JS中的DOM— —节点以及操作

    DOM操作在JS中可以说是非常常见了吧,很多网页的小功能的实现,比如一些元素的增删操作等都可以用JS来实现.那么在DOM中我们需要知道些什么才能完成一些功能的实现呢?今天这篇文章就先简单的带大家入一下 ...

  4. js中的DOM节点

    文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法. DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 把上面的代码拆分为Dom节 ...

  5. js获取HTML DOM节点元素方法总结

    1. 通过顶层document节点获取:    (1)document.getElementById(elementId) :通过ID获得节点,如果页面上含有多个相同id的节点,那么只返回第一个节点. ...

  6. JS 操作Dom节点之CURD

    许多优秀的Javascript库,已经封装好了丰富的Dom操作函数,这可以加快项目开发效率.但是对于非常注重网页性能的项目来说,使用Dom的原生操作方法还是必要的. 1. 查找节点 document. ...

  7. 原生JS的DOM节点操作

    DOM(Document Object Model/文档对象模型)是针对HTML和XML文档的一个API.DOM节点树:在文档中出现的空格.回车.标签.注释.文本.doctype.标签等都属于DOM节 ...

  8. vue.js插入dom节点的方式

    html代码: <div id="app"></div> js代码: var MyComponent = Vue.extend({ template: '& ...

  9. 原生JS获取DOM 节点到浏览器顶部的距离或者左侧的距离

    关于js获取dom 节点到浏览器顶/左部的距离,Jquery里面有封装好的offset().top/offset().left,只到父级的顶/左部距离position().top/position() ...

随机推荐

  1. Unity 视频播放杂谈

    http://www.cnblogs.com/zsb517/p/4060814.html 背景:      游戏机中想加入舞蹈元素,最先的想法是开发舞蹈游戏,然后通过动画来表现舞蹈,给用户提供舞蹈教学 ...

  2. [POJ3096]Surprising Strings

    [POJ3096]Surprising Strings 试题描述 The D-pairs of a string of letters are the ordered pairs of letters ...

  3. Laravel5.1-Eloquent ORM:起步

    概述 有很多朋友问,MCV的M是在哪里介绍的,这里就是介绍M的地方了.Laravel有一个强大的数据库ORM Eloquent,它的原理是每张数据表对应一个Model,对Model的操作就对应数据库的 ...

  4. hiho #1284 机会渺茫

    #1284 : 机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要 ...

  5. (转)一个JavaWeb项目开发总结

    原文地址:http://www.cnblogs.com/lzb1096101803/p/4907775.html 一.学会如何读一个JavaWeb项目源代码 步骤:表结构->web.xml-&g ...

  6. 【GoLang】golang runtime 调度原理

    参考资料: http://m.yl1001.com/group_article/3231471449287668.htm http://tieba.baidu.com/p/3542454435?sha ...

  7. JavaScript——同源策略

    概念:同源策略是客户端脚本(尤其是Javascript)的重要的安全度量标准.它最早出自Netscape Navigator2.0,其目的是防止某个文档或脚本从多个不同源装载.   这里的同源指的是: ...

  8. [转]Java 征途:行者的地图

    前段时间应因缘梳理了下自己的 Java 知识体系, 成文一篇望能帮到即将走进或正在 Java 世界跋涉的程序员们. 第一张,基础图 大约在 2003 年我开始知道 Java 的(当时还在用 Delph ...

  9. POI文件导出至EXCEL,并弹出下载框

    相关参考帖子 : [1]http://www.tuicool.com/articles/MnqeUr [2]http://www.oschina.net/question/253469_51638?f ...

  10. 【leetcode】Binary Tree Zigzag Level Order Traversal

    Binary Tree Zigzag Level Order Traversal Given a binary tree, return the zigzag level order traversa ...