博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DOM常用操作
阅读量:5123 次
发布时间:2019-06-13

本文共 2135 字,大约阅读时间需要 7 分钟。

  文档对象模型( DOM, Document Object Model )主要用于对HTML和XML文档的内容进行操作。DOM描绘了一个层次化的节点树,通过对节点进行操作,实现对文档内容的添加、删除、修改、查找等功能。

一、DOM树

DOM树有两种,分别为节点树元素树

  • 节点树:把文档中所有的内容都看成树上的节点;
  • 元素树:仅把文档中的所有标签看成树上的节点。

二、DOM常用操作

2.1 查找节点

document.getElementById('id属性值');

返回拥有指定id的第一个对象的引用

document/element.getElementsByClassName('class属性值');

返回拥有指定class的对象集合

document/element.getElementsByTagName('标签名');

返回拥有指定标签名的对象集合

document.getElementsByName('name属性值');

返回拥有指定名称的对象结合

document/element.querySelector('CSS选择器');

仅返回第一个匹配的元素

document/element.querySelectorAll('CSS选择器');

返回所有匹配的元素

document.documentElement

获取页面中的HTML标签

document.body

获取页面中的BODY标签

document.all['']

获取页面中的所有元素节点的对象集合型

 

 

 

 

 

 

 

 

 

 

2.2 新建节点

document.createElement('元素名');

创建新的元素节点

document.createAttribute('属性名');

创建新的属性节点

document.createTextNode('文本内容');

创建新的文本节点

document.createComment('注释节点');

创建新的注释节点

document.createDocumentFragment( );

创建文档片段节点

 

 

 

 

 

 

 

2.3 添加新节点

parent.appendChild( element/txt/comment/fragment );

向父节点的最后一个子节点后追加新节点

parent.insertBefore( newChild, existingChild );

向父节点的某个特定子节点之前插入新节点

element.setAttributeNode( attributeName );

给元素增加属性节点

element.setAttribute( attributeName, attributeValue );

给元素增加指定属性,并设定属性值

 

 

 

 

 

添加文本节点,有两种常见方法:

  • document.createTextNode('新增文本内容');
1  2  3  4     
5 Document 6 7 8

创建文本节点

9 10

11 18 19

 

  • element.innerHTML='新增文本内容'; 【推荐】
1  2  3  4     
5 Document 6 7 8

创建文本节点

9 10

11 17 18

 

 

2.4 删除节点

parentNode.removeChild( existingChild );

删除已有的子节点,返回值为删除节点

element.removeAttribute('属性名');

删除具有指定属性名称的属性,无返回值

element.removeAttributeNode( attrNode );

删除指定属性,返回值为删除的属性 

 

 

 

 

 

2.5 修改节点

parentNode.replaceChild( newChild, existingChild );

用新节点替换父节点中已有的子节点
element.setAttributeNode( attributeName ); 若原元素已有该节点,此操作能达到修改该属性值的目的
element.setAttribute( attributeName, attributeValue ); 若原元素已有该节点,此操作能达到修改该属性值的目的

 

 

 

 

 

添加属性节点,修改属性值:

  • element.setAttributeNode( attributeName );
1  2  3  4     
5 Document 6 7 8

属性节点

9

增添id属性,并修改class属性值

10 15 16

 

  • element.setAttribute( attributeName, attributeValue );
1  2  3  4     
5 Document 6 7 8

属性节点

9

增添id属性,并修改class属性值

10 23 24

 

 

 

转载于:https://www.cnblogs.com/yinshuige/p/5812095.html

你可能感兴趣的文章
GIT在Linux上的安装和使用简介
查看>>
基于C#编程语言的Mysql常用操作
查看>>
s3c2440实验---定时器
查看>>
MyEclipse10安装SVN插件
查看>>
[转]: 视图和表的区别和联系
查看>>
Regular Experssion
查看>>
图论例题1——NOIP2015信息传递
查看>>
uCOS-II中的任务切换-图解多种任务调度时机与问题
查看>>
CocoaPods的安装和使用那些事(Xcode 7.2,iOS 9.2,Swift)
查看>>
Android 官方新手指导教程
查看>>
幸运转盘v1.0 【附视频】我的Android原创处女作,请支持!
查看>>
UseIIS
查看>>
集合体系
查看>>
vi命令提示:Terminal too wide
查看>>
引用 移植Linux到s3c2410上
查看>>
MySQL5.7开多实例指导
查看>>
[51nod] 1199 Money out of Thin Air #线段树+DFS序
查看>>
poj1201 查分约束系统
查看>>
Red and Black(poj-1979)
查看>>
分布式锁的思路以及实现分析
查看>>