首页登陆欢迎您!
首页登陆 > 前端 > DOM Element节点类型详整

DOM Element节点类型详整

时间:2019-12-06

DOM Element节点类型详整

2015/09/21 · HTML5 · DOM

本文小编: 伯乐在线 - 韩子迟 。未经小编许可,防止转发!
迎接出席伯乐在线 专栏编辑者。

上文中我们讲明了 DOM 中最器重的节点类型之黄金时代的 Document 节点类型,本文大家后续浓烈,谈谈另二个首要的节点类型 Element 。

1.dom对象的innerText和innerHTML有啥样分别?

  • innerText:文本格式插入
  • innerHTML:支持HTML插入,解析HTML标签

DOM成分的attribute和property非常轻巧混倄在一块儿,分不清楚,两个是例外的事物,不过两岸又联系紧凑。比较多新手朋友,也席卷从前的自个儿,日常会搞不清楚。

1、概况


Element 类型用于表现 HTML 或 XML 成分,提供了对成分标具名、子节点及特色的拜谒。 Element 节点有所以下特点:

  1. nodeType 的值为 1
  2. nodeName 的值为成分的标具名
  3. nodeValue 的值为null
  4. parentNode 可能是 Document 或者 Element
  5. 其子节点大概是 ElementTextCommentProcessingInstructionCDATASection 或者 EntityReference

要拜谒成分的标具名,能够用 nodeName 属性,也能够用 tagName 属性;那多个属性会重临相仿的值。在 HTML 中,标具名始终都是任何大写表示,而在 XML(有的时候候也囊括 XHTML)中,标具名始终和源代码中保持豆蔻梢头致。如若你不明确自身的脚本将会在 HTML 依旧 XML 文书档案中施行,最棒照旧在相比较前边将标签字调换来相像的尺寸写方式:

JavaScript

var myDiv = document.querySelector('div'卡塔尔(英语:State of Qatar); console.log(myDiv.tagName卡塔尔(英语:State of Qatar); // DIV console.log(myDiv.nodeName卡塔尔(قطر‎; // DIV if (myDiv.tagName.toLowerCase(卡塔尔国 === 'div'卡塔尔国 { // 那样最棒,适用于任何文书档案 // ... }

1
2
3
4
5
6
7
var myDiv = document.querySelector('div');
console.log(myDiv.tagName);  // DIV
console.log(myDiv.nodeName);  // DIV
 
if (myDiv.tagName.toLowerCase() === 'div') { // 这样最好,适用于任何文档
  // ...
}

2.elem.children和elem.childNodes的区别?

  • element.children 获取的是近日因素的具备子节点成分(不包罗文件成分),children再次来到的是HTMLCollection类型
  • element.childNodes 获取的是近些日子成分的有所子成分(节点成分和文件成分),childNodes重回的是NodeList类型

前端,attribute翻译成普通话术语为“天性”,property翻译成中文术语为“属性”,从汉语的字面意思来看,确实是有一些分别了,先来讲说attribute。

2、HTML 元素


享有 HTML 成分都由 HTMLElement 类型表示,不是直接通过这么些连串,也是由此它的子类型来代表。 HTMLElement 类型直接接轨自 Element 并增加了有的性质。每一个 HTML 元素中都设有下列标准属性:

  1. id 成分在文书档案中的唯黄金时代标志符
  2. title 有关因素的增大表明音信,平日通过工具提醒条展现出来
  3. lang 成分内容的言语代码,少之又少使用
  4. dir 语言的动向,值为 ltr 或者 rtl,也少之甚少使用
  5. className 与成分的 class 本性对应

3.查询成分有二种布满的格局?ES5的因素选择方式是何许?

attribute是二个特色节点,每一种DOM元素都有八个一呼百诺的attributes属性来贮存全体的attribute节点,attributes是八个类数组的容器,说得正确点就是NameNodeMap,同理可得就是四个相通数组但又和数组不太意气风发致的容器。attributes的各类数字索引以名值对(name=”value”卡塔尔(قطر‎的款型存放了贰个attribute节点。

3、本性的获得和设置


每一个成分都有二个或四个天性,那一个特征的用项是付出相应成分或其剧情的叠合消息。操作天性的 DOM 方法主要有多个,分别是getAttribute() setAttribute() removeAttribute()

注意,传递给 getAttribute() 的表征名与事实上的性状名肖似,因而要想博得 class 天性值,应该传入 class 而不是 className,前者独有在经过对象属性(property)访问天性时才用。要是给定称号的特点不设有,getAttribute() 返回 null。

<div id='myDiv' title='hanzichi'> </div> <script> var myDiv = document.querySelector('div'); // attribute console.log(myDiv.getAttribute('id')); // myDiv console.log(myDiv.getAttribute('class')); // null console.log(myDiv.getAttribute('title')); // hanzichi console.log(myDiv.getAttribute('lang')); // null console.log(myDiv.getAttribute('dir')); // null // property console.log(myDiv.id); // myDiv console.log(myDiv.className); // '' console.log(myDiv.title); // hanzichi console.log(myDiv.lang); // '' console.log(myDiv.dir); // '' </script>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<div id='myDiv' title='hanzichi'> </div>
<script>
  var myDiv = document.querySelector('div');
 
  // attribute
  console.log(myDiv.getAttribute('id')); // myDiv
  console.log(myDiv.getAttribute('class')); // null
  console.log(myDiv.getAttribute('title')); // hanzichi
  console.log(myDiv.getAttribute('lang')); // null
  console.log(myDiv.getAttribute('dir')); // null
 
  // property
  console.log(myDiv.id); // myDiv
  console.log(myDiv.className); // ''
  console.log(myDiv.title); // hanzichi
  console.log(myDiv.lang); // ''
  console.log(myDiv.dir); // ''
</script>

透过 getAttribute(卡塔尔(英语:State of Qatar) 方法也能够博得自定义天性。

在事实上付出中,开辟人士不经常用 getAttribute(),而是只使用对象的性质(property)。独有在获取自定义本性值的图景下,才使用getAttribute() 方法。为啥吧?比方说 style,在通过 getAttribute() 访问时,返回的 style 本性值富含的是 css 文本,而经过属性来访谈会回来叁个对象。再例如 onclick 那样的事件管理程序,当在要素上利用时,onclick 天性蕴涵的是 Javascript 代码,假如经过 getAttribute() 访谈,将会回到相应代码的字符串,而在做客 onclick 属性时,则会回到 Javascript 函数。

与 getAttribute() 对应的是 setAttribute(),这么些点子选择四个参数:要安装的特色名和值。借使性情已经存在,setAttribute()会以内定的值替换现成的值;借使性格不设有,setAttribute() 则创立该属性并安装相应的值。

而 removeAttitude() 方法用于深透去除元素的特点。调用这些方法不止会去掉本性的值,并且也会从要素中完全除去天性。

JavaScript

div.setAttribute('id', 'someOtherId'); div.setAttribute('title', 'some other text'); div.removeAttribute('class')

1
2
3
4
div.setAttribute('id', 'someOtherId');
div.setAttribute('title', 'some other text');
 
div.removeAttribute('class')

document方法:

  • document.getElementById()
    getElementById方法重回匹配钦点id属性的因秋日点。若无意识相配的节点,则赶回null。
    以此办法只好在document对象上行使,不能够在其余因初秋点上选择。
  • document.getElementsByTagName()
    document.getElementsByTagName方法再次来到全数钦命HTML标签的成分,重返值是三个好像数组的HTMLCollection对象,能够实时反映HTML文书档案的变迁。若无此外相配的成分,就回到三个空集。不仅可以够在document对象上调用,也能够在别的因金秋点上调用。
  • docuemnt.getElementsByClassName()
    document.getElementsByClassName方法重回三个近乎数组的指标(HTMLCollection实例对象),包罗了具备class名字相符钦定条件的因素,成分的变通实时反映在回到结果中。不仅可以够在document对象上调用,也足以在此外因初秋点上调用。
  • document.getElementsByName()
    document.getElementsByName方法用于接收具备name属性的HTML成分(比如<form>、<radio>、<img>、<frame>、<embed>和<object>等),再次来到一个相同数组的的靶子(NodeList对象的实例),因为name属性相通的因素只怕持续三个。
  • document.elementFromPoint
    document.elementFromPoint方法重返坐落于页面钦定地方最上层的Element子节点。

复制代码 代码如下:

4、attributes 属性


Element 类型是运用 attributes 属性的唯大器晚成二个 DOM 节点类型。 attributes 属性中带有多少个 NamedNodeMap,与 NodeList 相像,也是一个“动态”的汇集。成分的每叁个特点都由二个 Attr 节点表示,各种节点都保留在 NamedNodeMap 对象中。NamedNodeMap 对象具有下列方式:

  1. getNamedItem(name): 返回 nodeName 属性等于 name 的节点
  2. removeNamedItem(name): 从列表移除 nodeName 属性等于 name 的节点
  3. setNamedItem(node): 向列表中加多节点,以节点的 nodeName 属性为索引
  4. item(pos): 重临坐落于数字 pos 地方处的节点

attributes 属性中带有豆蔻年华多级的节点,每种节点的 nodeName 就是特色的名目,而节点的 nodeValue 便是特色的值。

JavaScript

// 得到成分的特征值 var id = element.attributes.getNamedItem('id'卡塔尔国.nodeValue; var id = element.attributes['id'].nodeValue; // getAttribute(卡塔尔(قطر‎ 也能促成平等功能var id = element.getAttribute('id'卡塔尔国; // 与removeAttribute(卡塔尔方法比较,唯意气风发的不一致是能回去表示被去除特性的节点 var oldAttr = element.attributes.removeNamedItem('id'卡塔尔(英语:State of Qatar); // 增添新特色 // 须求传入叁个风味节点 element.attributes.setNamedItem(newAttr卡塔尔国;

1
2
3
4
5
6
7
8
9
10
11
12
13
// 取得元素的特性值
var id = element.attributes.getNamedItem('id').nodeValue;
var id = element.attributes['id'].nodeValue;
 
// getAttribute() 也能实现一样功能
var id = element.getAttribute('id');
 
// 与removeAttribute() 方法相比,唯一的区别是能返回表示被删除特性的节点
var oldAttr = element.attributes.removeNamedItem('id');
 
// 添加新特性
// 需要传入一个特性节点
element.attributes.setNamedItem(newAttr);

雷同的话,由于前面介绍的 attributes 方法非常不足方便,由此开采人士更加多的会使用 getAttribute() removeAttribute() 以及setAttribute() 方法。

唯独如果想要遍历成分的表征,attributes 属性倒是能够派上用途:

<div id='myDiv' title='hanzichi' class='fish'> </div> <script> var myDiv = document.querySelector('div'); for (var i = 0, len = myDiv.attributes.length; i < len; i++) { var attrName = myDiv.attributes[i].nodeName , attrValue = myDiv.attributes[i].nodeValue; console.log(attrName, attrValue); } // id myDiv // title hanzichi // class fish </script>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<div id='myDiv' title='hanzichi' class='fish'> </div>
<script>
  var myDiv = document.querySelector('div');
  for (var i = 0, len = myDiv.attributes.length; i < len; i++) {
    var attrName = myDiv.attributes[i].nodeName
      , attrValue = myDiv.attributes[i].nodeValue;
 
    console.log(attrName, attrValue);
  }
 
  // id myDiv
  // title hanzichi
  // class fish
</script>

ES5的方法:

  • document.querySelector()
    document.querySelector方法接纳四个CSS选拔器作为参数,重临相称该采纳器的要白藏点。假若有四个节点满足相配原则,则赶回第一个门户差不多的节点。若无发觉相称的节点,则赶回null
  • document.querySelectorAll()
    document.querySelectorAll方法与querySelector用法相像,差别是回去四个NodeList对象,满含全部相称给定选拔器的节点。

<div class="box" id="box" gameid="880">hello</div>

5、成分的子节点


<ul id='myUl'> <li> Item 1 </li> <li> Item 2 </li> <li> Item 3 </li> </ul> <script> var myUl = document.getElementById('myUl'卡塔尔国; console.log(myUl.childNodes.length卡塔尔; // IE: 3 别的浏览器: 7 </script>

1
2
3
4
5
6
7
8
9
10
<ul id='myUl'>
  <li> Item 1 </li>
  <li> Item 2 </li>
  <li> Item 3 </li>
</ul>
 
<script>
  var myUl = document.getElementById('myUl');
  console.log(myUl.childNodes.length); // IE: 3   其他浏览器: 7
</script>

以上代码,假如是 IE 来剖析,那么 <ul> 成分会有 3 个子节点,分别是 3 个 <li> 成分;而风度翩翩旦是其余浏览器深入分析,则会有 7 个子节点,包括 3 个 <li> 元素 和 4 个文件节点。

假诺像下边那样将成分之间的空白符删除,那么具备浏览器都会回来相符数量的子节点:

<ul id='myUl'><li> Item 1 </li><li> Item 2 </li><li> Item 3 </li></ul> <script> var myUl = document.getElementById('myUl'卡塔尔; console.log(myUl.childNodes.length卡塔尔; // 全体浏览器: 3 </script>

1
2
3
4
5
6
<ul id='myUl'><li> Item 1 </li><li> Item 2 </li><li> Item 3 </li></ul>
 
<script>
  var myUl = document.getElementById('myUl');
  console.log(myUl.childNodes.length); // 所有浏览器: 3
</script>

 

打赏支持自身写出越来越多好小说,多谢!

打赏作者

4.怎么创制二个成分?怎样给成分设置属性?怎样删除属性

  • document.createElement()
    document.createElement方法用来生成网页成分节点。
var newDiv = document.createElement('div');```
createElement方法的参数为元素的标签名,即元素节点的tagName属性,对于 HTML 网页大小写不敏感,即参数为div或DIV返回的是同一种节点。如果参数里面包含尖括号(即<和>)会报错。

<body>
<div id="div1" class='test'>ss</div>
<script charset="utf-8">
var body = document.getElementsByTagName('body'卡塔尔(قطر‎//获取节点
var newDiv = document.createElement('div'卡塔尔(英语:State of Qatar)//创立成分
newDiv.setAttribute('id','xxx'卡塔尔(英语:State of Qatar)//设置属性
var newContent = document.createTextNode('hello world'卡塔尔(قطر‎ //创制文本节点
body[0].appendChild(newDiv卡塔尔国//插入节点
newDiv.appendChild(newContent卡塔尔国 //插入文本节点
document.getElementById('div1'卡塔尔(英语:State of Qatar).removeAttribute('class'卡塔尔(قطر‎//删除属性
</script>
</body>```

地方的div成分的HTML代码中有class、id还大概有自定义的gameid,那一个特色都存放在attributes中,相仿下边包车型客车款式:

打赏帮助我写出更加多好小说,感激!

前端 1

1 赞 1 收藏 评论

5.怎么给页面成分加多子成分?如何删除页面成分下的子成分?

<body>
      <div id="div1" class='test'>div1</div>
      <div id="div2">div2</div>
      <div id="div3">div3</div>
      <div id="div4">div4</div>
      <div id="div5">div5</div>
      <script charset="utf-8">
        var body = document.getElementsByTagName('body')
        var newDiv = document.createElement('div')
        newDiv.setAttribute('id','xxx')
        var newContent = document.createTextNode('hello world') 
        body[0].appendChild(newDiv)//页面元素添加子元素
        newDiv.appendChild(newContent)     
        document.getElementById('div1').removeAttribute('id')
        body[0].removeChild(document.getElementById('div4'))//删除页面元素下的子元素
        document.getElementById('div2').remove()//删除元素本身
      </script>
    </body>```
# 6.element.classList有哪些方法?如何判断一个元素的 class 列表中是包含某个 class?如何添加一个class?如何删除一个class?
- className属性用来读写当前元素节点的class属性。它的值是一个字符串,每个class之间用空格分割。
- classList属性则返回一个类似数组的对象,当前元素节点的每个class就是这个对象的一个成员。
#### classList对象有下列方法。

>add():增加一个class。
remove():移除一个class。
contains():检查当前元素是否包含某个class。
toggle():将某个class移入或移出当前元素。
item():返回指定索引位置的class。
toString():将class的列表转为字符串。

myDiv.classList.add('myCssClass'卡塔尔;//增添三个class
myDiv.classList.add('foo', 'bar'卡塔尔(قطر‎;//增多四个class
myDiv.classList.remove('myCssClass');//删除一个class
myDiv.classList.toggle('myCssClass'卡塔尔(英语:State of Qatar); // 假若myCssClass不设有就步入,存在就移除
myDiv.classList.contains('myCssClass'); // 返回 true 或者 false
myDiv.classList.item(0卡塔尔(英语:State of Qatar); // 重临第一个Class
myDiv.classList.toString(卡塔尔(英语:State of Qatar);//将classList对象调换为字符串与.className效果等同

# 7.如何选中如下代码所有的li元素? 如何选中btn元素?

<div class="mod-tabs">
<ul>
<li>list1</li>
<li>list2</li>
<li>list3</li>
</ul>
<button class="btn">点我</button>
</div>
<script>
var liAll = document.getElementsByTagName('li'卡塔尔//选中具备li元素分娩类数组对象
var btn = document.getElementsByClassName('btn')//选中btn元素
</script>

复制代码 代码如下:

有关小编:韩子迟

前端 2

a JavaScript beginner 个人主页 · 小编的稿子 · 9 ·    

前端 3

[ class="box", id="box", gameid="880" ]

能够这么来拜访attribute节点:

复制代码 代码如下:

var elem = document.getElementById( 'box' );
console.log( elem.attributes[0].name ); // class
console.log( elem.attributes[0].value ); // box

而是IE6-7将过多事物都贮存在attributes中,上边的访问方法和正规浏览器的归来结果又区别。平常要获得叁个attribute节点直接用getAttribute方法:

复制代码 代码如下:

上一篇:HTML5 录音的踩坑之旅 下一篇:没有了