大家好~ 我是一枚正直纯洁的苦逼程序员!!!!!
常见DOM操作有哪些?
1.背景介绍
DOM是什么? DOM 是 Document Object Model(文档对象模型)的缩写。
DOM是中立于平台和语言的接口,它允许程序和脚本动态地访问和更新文档的内容、结构和样式。
在 HTML DOM中,所有事物都是节点。DOM 是被视为节点树的 HTML。
2.知识剖析
什么是DOM节点?
HTML 文档中的所有内容都是节点
整个文档是一个文档节点
每个 HTML 元素是元素节点
HTML 元素内的文本是文本节点
每个 HTML 属性是属性节点
注释是注释节点
3.常见问题
常见的DOM操作,访问元素的方法和DOM属性有哪些?
4.解决方案
一.常见的dom操作
通过使用 getElementById() 方法。
通过使用 getElementsByTagName() 方法
通过使用 getElementsByClassName() 方法。
二.访问属性的方法
getElementsByTagName() 方法
可返回带有指定标签名的对象的集合。
返回元素的顺序是它们在文档中的顺序。
传递给 getElementsByTagName() 方法的字符串可以不区分大小写。
getElementsByClassName() 方法
获取所有指定类名的元素:
getElementsByClassName() 方法返回文档中所有指定类名的元素集合,作为 NodeList 对象。
NodeList 对象代表一个有顺序的节点列表。NodeList 对象 我们可通过节点列表中的节点索引号来访问列表中的节点(索引号由0开始)。
可以使用 NodeList 对象的 length 属性来确定指定类名的元素个数,并循环各个元素来获取你需要的那个元素。
getElementById() 方法
getElementById() 方法可返回对拥有指定 ID 的第一个对象的引用。
如果您需要查找文档中的一个特定的元素,最有效的方法是 getElementById()。
在操作文档的一个特定的元素时,最好给该元素一个 id 属性,为它指定一个(在文档中)唯一的名称,然后就可以用该 ID 查找想要的元素。
常见的DOM属性
1. innerHTML 属性
获取元素内容的最简单方法是使用 innerHTML 属性。
innerHTML 属性对于获取或替换 HTML 元素的内容很有用。
2. nodeName 属性
nodeName 属性规定节点的名称。
nodeName 是只读的
元素节点的 nodeName 与标签名相同
属性节点的 nodeName 与属性名相同
文本节点的 nodeName 始终是 #text
文档节点的 nodeName 始终是 #document
3.nodeValue 属性
nodeValue 属性规定节点的值。
元素节点的 nodeValue 是 undefined 或 null
文本节点的 nodeValue 是文本本身
属性节点的 nodeValue 是属性值
5.编码实战
dome
6.扩展思考
修改元素的html内容和css样式的方法
改变 HTML 内容
document.getElementById("p1").innerHTML="New text!";
改变 CSS 样式
document.getElementById("p2").style.color="blue";
7.参考文献
8.更多讨论
1.除了这三种方法还有那些方法?
解决:
document/element.querySelector('CSS选择器');
document/element.querySelectorAll('CSS选择器');
document.createTextNode('文本内容');等等
2.对下标的理解?
解决:
下标就是从0开数
3.改变 CSS 样式还可以用什么属性?
解决:
classNane