奥门金沙手机娱乐网址 3

DOM Element节点类型安详严整

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’卡塔尔国; 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(卡塔尔(قطر‎ 方法也得以获取自定义本性。

在实质上开拓中,开垦职员一时用 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接收器作为参数,重临匹配该接纳器的成分节点。假使有三个节点满意相称原则,则赶回第1个门道拾贰分的节点。若无发现匹配的节点,则赶回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’卡塔尔(英语:State of Qatar);
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卡塔尔(英语:State of Qatar); // 全体浏览器: 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’卡塔尔//创变成分
newDiv.setAttribute(‘id’,’xxx’卡塔尔国//设置属性
var newContent = document.createTextNode(‘hello world’卡塔尔国 //创造文本节点
body[0].appendChild(newDiv卡塔尔//插入节点
newDiv.appendChild(newContent卡塔尔(قطر‎ //插入文本节点
document.getElementById(‘div1’卡塔尔国.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’卡塔尔; //
若是myCssClass荒诞不经就步向,存在就移除
myDiv.classList.contains(‘myCssClass’); // 返回 true 或者 false
myDiv.classList.item(0卡塔尔; // 再次来到第二个Class
myDiv.classList.toString(卡塔尔(قطر‎;//将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’卡塔尔(英语:State of Qatar)//选中装有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方法:

复制代码 代码如下: