常见的Dom操作
1.什么是DOM?
DOM又称文档对象模型( DOM, Document Object Model )主要用于对HTML和XML文档的内容进行操作。DOM描绘了一个层次化的节点树,通过对节点进行操作,实现对文档内容的添加、删除、修改、查找等功能。
2.什么是DOM树?
DOM树有两种,分别为节点树和元素树。
节点树:把文档中所有的内容都看成树上的节点;
元素树:仅把文档中的所有标签看成树上的节点。
3.DOM常用操作
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.新建节点
document.createElement('元素名'); |
创建新的元素节点 |
document.createAttribute('属性名'); |
创建新的属性节点 |
document.createTextNode('文本内容'); |
创建新的文本节点 |
document.createComment('注释节点'); |
创建新的注释节点 |
document.createDocumentFragment( ); |
创建文档片段节点 |
3.添加新节点 注(添加新节点和新建节点不同,新建的节点如果不添加到DOM中,是不会有任何效果的)
parent.appendChild( element/txt/comment/fragment ); |
向父节点的最后一个子节点后追加新节点 |
parent.insertBefore( newChild, existingChild ); |
向父节点的某个特定子节点之前插入新节点 |
element.setAttributeNode( attributeName ); |
给元素增加属性节点 |
element.setAttribute( attributeName, attributeValue ); |
给元素增加指定属性,并设定属性值 |
4.删除节点
parentNode.removeChild( existingChild ); |
删除已有的子节点,返回值为删除节点 |
element.removeAttribute('属性名'); |
删除具有指定属性名称的属性,无返回值 |
element.removeAttributeNode( attrNode ); |
删除指定属性,返回值为删除的属性 |
5.修改节点
parentNode.replaceChild( newChild, existingChild ); |
用新节点替换父节点中已有的子节点 |
element.setAttributeNode( attributeName ); | 若原元素已有该节点,此操作能达到修改该属性值的目的 |
element.setAttribute( attributeName, attributeValue ); | 若原元素已有该节点,此操作能达到修改该属性值的目的 |
不多说了,直接上代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<h2>创建文本节点</h2>
<button onclick="addText()">创建文本节点</button>
<p></p>
<script>
function addText(){
//创建文本节点
var a=document.createTextNode('this is a 文本'); //创建文本节点
document.getElementsByTagName('p')[0].appendChild(a);//添加文本节点
document.getElementsByTagName('button')[0].innerHTML='你看我变了没?';//新增文本内容
var b=document.createAttribute('id'); //创建一个属性节点 也可以在创建时给他赋值
b.value='123'; //给这个属性节点赋值
document.getElementsByTagName('p')[0].setAttributeNode(b); //给p元素设置新的属性
document.getElementsByTagName('button')[0].setAttribute('id','buttonId'); //给button元素设置id属性
//创建新元素
var c=document.createElement('div'); //创建一个新元素div
var cul=document.createElement('ul'); //创建一个新元素 ul
var culli=document.createElement('li'); //创建一个新元素 li
culli.innerHTML='6'; // 新增文本内容
c.appendChild(cul).appendChild(culli); //添加子节点
document.body.appendChild(c); //往body中添加子节点 //等同于:
//var d="<ul><li>6</li>"; //字符串
//c.append(d); //jquery append方法
//document.body.appendChild(c); }
</script>
</body>
</html>
常见的Dom操作的更多相关文章
- JavaScript常见原生DOM操作API总结
[TOC] 最近面试的时候被这个问题给卡了,所以抽时间好好复习一下. 几种对象 Node Node是一个接口,中文叫节点,很多类型的DOM元素都是继承于它,都共享着相同的基本属性和方法.常见的Node ...
- JS中常见原生DOM操作API
摘自:https://blog.csdn.net/hj7jay/article/details/53389522 几种对象 Node Node是一个接口,中文叫节点,很多类型的DOM元素都是继承于它, ...
- 常见的dom操作----原生JavaScript与jQuery
1.创建元素 文本节点 JavaScript: document.createElement(),只接收一个参数,创建后需要手动将其添加到文档树中,例如: var newDiv = document. ...
- 前端页面卡顿?或是DOM操作惹的祸,需优化代码
文档对象模型(DOM)是一个独立 于特定语言的应用程序接口.在浏览器中,DOM接口是以JavaScript语言实现的,通过JavaScript来操作浏览器页面中的元素,这使得 DOM成为了JavaSc ...
- DOM操作优化
文档对象模型(DOM)是一个独立 于特定语言的应用程序接口.在浏览器中,DOM接口是以JavaScript语言实现的,通过JavaScript来操作浏览器页面中的元素,这使得 DOM成为了JavaSc ...
- 解析XML文件的几种常见操作方法—DOM/SAX/DOM4j
解析XML文件的几种常见操作方法—DOM/SAX/DOM4j 一直想学点什么东西,有些浮躁,努力使自己静下心来看点东西,哪怕是回顾一下知识.看到了xml解析,目前我还没用到过.但多了解一下,加深点记忆 ...
- DOM操作 append prependTo after before
通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作.但实际上一般开发者都习惯性的先定义好HTML结构,但这样就非常不灵活了. 试想下这样的情况:如果我们通过AJAX获取到数 ...
- JQuery基础DOM操作
DOM创建节点及节点属性 通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作.但实际上一般开发者都习惯性的先定义好HTML结构,但这样就非常不灵活了. 试想下这样的情况:如 ...
- DOM操作--表格点击行变色
点击表格行变色,这种网页效果应该还是比较常见的.大家应该看见了,我这里的效果是用DOM操作实现的,那么很多人会问什么是DOM操作,贴出代码之前我就和大家解释一下什么是DOM操作: DOM是Docume ...
随机推荐
- asp.net中<input type=button>无法调用后台函数
例如:用<input id="bt1" type="button" runat="server" Onclick="btnL ...
- 闭包中的this
var name="pushline";//全局变量 var obj=new Object(); obj.name="jms"; obj.getName=fun ...
- win10下clodeblocks编译C语言乱码
打开settings->compile,在other compiler options添加下面两行代码: -fexec-charset=GBK-finput-charset=UTF-8
- Ubuntu setup ftp server.
http://www.cnblogs.com/bcsflilong/p/4200139.html Steps 1. Install vsftpd sudo apt-get install vsftpd ...
- log4j2单独的配置与使用&log4j2+slf4j的结合的配置与使用
转载自:https://github.com/iamyong 一.log4j2单独的配置与使用 所用jar文件 log4j-api-2.8.2.jar log4j-core-2.8.2.jar 配置文 ...
- 狂欢圣诞节,Azure云邀你一起云端跑酷!
想要速度更快? 希望绕过障碍? 还想安全抵达目的地? …… 平安夜夜游时的各种畅想,不也正是 IT 同事所追求的,更是业务发展的终极目标呀. 好啦,小编说的太多了,这样不好不好.过节休息不谈工作,那就 ...
- 深入理解JVM读书笔记思维导图
为了证明我已经啃完这本书然后买新书不用剁手...脑图画了8个钟,感觉整个人都不好了T_T 脑细胞不知道死了多少... 其实没吃透,估计若干年后要重新翻开来看...
- JS教程之实现加载图片时百分比进度
思路:思路其实很简单,ajax执行时,会生成一个event对象,其中会包含要加载的文件的大小和当前已经加载完成部分的大小,通过这两个值即可计算出百分比 事件介绍onprogress 当浏览器正在加载媒 ...
- Wi-Fi
AP就是一个无线的交换机,提供无线信号发射接收的功能 Wi-Fi是一种可以将个人电脑.手持设备(如PDA.手机)等终端以无线方式互相连接的技术 两个不一样的东西,无法比较的 你说的应该是无线路由器和无 ...
- python入门18 继承和多态
继承:子类继承父类的属性和方法 class 子类名(父类1,父类2) 多态:子类重写父类的方法 判断对象是否是某个类的实例: isinstance(object,class) 父类-汽车类 #co ...