javascript DOM基本操作
javascript DOM基本操作
1.DOM(Document Object Model 文档对象模型)
2.节点:
- 文档节点:document
- 元素节点:html、head、body、title、meta、h1、p等
- 属性节点:attr
- 文本节点:text
2.1节点获取
- documen.getElementById("元素ID") //返回含有该ID的元素
- document.getElementsByName("元素name属性") //返回带有指定名称元素的集合
- document.getElementsByTagName("元素标签") //返回指定元素的集合
2.2属性节点处理
- elementNode.hasAttribute("attrName") // 检测所选元素是否有attrName属性 eg:documen.getElementById("nav").hasAttribute("class")
- elementNode.getAttribute("attrName") //获取元素attrName属性的值
- elementNode.setAttribute("attrName","attrValue") //设置属性,创建或改变元素属性值
- elementNode.removeAttribute("attrName") //移除属性
- 注意:在获取属性和移除属性时,用hasAttribute()方法判断此属性是否存在
2.3文本节点处理
- 通过innerHTML属性获取和设置文本节点属性
- documen.getElementById("content").innerHTML="<p>hello!</p>"
3遍历DOM
- 父节点.firstChild //获取元素的首个子节点
- 父节点.lastChild //获取元素最后一个子节点
- 父节点.childNode //获取元素子节点列表
- 子节点.parentNode // 获取已知节点父节点
- 兄弟节点.previousSibling //获取已知节点前一个节点
- 兄弟节点.nextSibling //获取已知节点后一个节点
- 注意:使用以上属性(除parentNode),有些浏览器将空格作为文本节点,因此浏览器就会将文本节点当做元素的兄弟节点来处理。
- 通过添加nodeType判断,若下一个或上一个是文本节点则继续寻找,直到找到元素节点
- nodeType 获得标签类型,nodeName 获得标签名称
- 元素节点的nodeType属性值是1,属性节点的nodeType属性值为2,文本节点的nodeType属性值3
- 如果该nextSibling.nodeName = #text,则通过nextSibling.nodeValue来获知其文本值;
- 否则,可以通过nextSibling.innerHTML等其他常用标签元素属性来获取其属性
4.节点操作
4.1创建节点
- document.createElement(元素标签) // 创建元素节点
- document.createAttribute(元素属性) // 创建属性节点
- document.createTextNode(文本内容) // 创建文本节点
4.2插入节点
- appendChild(所添加的新节点) //向节点的子节点末尾添加子节点
- insertBefore(所要添加的新节点,已知节点) //在已知子节点前面插入子节点
4.3替换节点
- replaceChild(要插入新元素,将要替换元素)
4.4复制节点
- 需要被复制节点.cloneNode(true/false) //创建指定节点副本,true复制当前节点及其子节点;false仅复制当前节点不包括文本
4.5删除节点
- removeChild(要删除节点) // 删除指定节点
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head> <body>
<ul id="tar_area"><li id="p1">1</li><li id="p2">2</li><li id="p3">3</li><li id="p4">4</li><li id="p5"></li>5</ul>
<input type="button" value="点我有惊喜!" onclick="test()" />
<script>
//向DOM中添加新元素
var targetArea=document.getElementById("tar_area");
var p1=document.getElementById("p1");
var p2=document.getElementById("p2");
var p3=document.getElementById("p3");
var p4=document.getElementById("p4");
var p5=document.getElementById("p5");
//添加节点
var p=document.createElement("p"); //创建元素
var text=document.createTextNode("这是js动态创建的元素"); //创建文本节点
p.appendChild(text); //向节点的子节点末尾添加子节点
targetArea.appendChild(p); //替换节点
targetArea.replaceChild(p,p2); //复制节点
var newNode=p3.cloneNode(true); //默认为true
targetArea.replaceChild(newNode,p1); //动态删除元素
targetArea.removeChild(p4); function test(){
var tar=document.getElementById("tar_area");
var p5=document.getElementById("p5");
var px=document.createElement("p");
var txt=document.createTextNode("hello!");
px.appendChild(txt);
tar.insertBefore(px,p5); //在已知节点前面插入子节点
}
</script>
</body>
</html>
javascript DOM基本操作的更多相关文章
- JavaScript思维导图—DOM基本操作
JavaScript思维导图-来自@王子墨http://julying.com/blog/the-features-of-javascript-language-summary-maps/ DOM基本 ...
- javascript DOM操作HTML文档
文档对象模型(DOM)是W3C为解决浏览器混战时代不同浏览器环境之间的差别而制定的模型标准.W3C将文档对象模型定义为:是一个能让程序和脚本动态 访问和更新文档内容.结构和样式的语言平台.提供了标准的 ...
- 读书笔记:JavaScript DOM 编程艺术(第二版)
读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...
- javascript DOM 操作 attribute 和 property 的区别
javascript DOM 操作 attribute 和 property 的区别 在做 URLRedirector 扩展时,注意到在使用 jquery 操作 checkbox 是否勾选时,用 at ...
- JavaScript DOM 编程艺术·setInterval与setTimeout的动画实现解析
先贴上moveElement()函数的大纲,为了方便观看,删了部分代码,完整版粘到文章后面. function moveElement(elementID,final_x,final_y,interv ...
- javascript DOM 操作
在javascript中,经常会需要操作DOM操作,在此记录一下学习到DOM操作的知识. 一.JavaScript DOM 操作 1.1.DOM概念 DOM :Document Object Mode ...
- javascript DOM操作之 querySelector,querySelectorAll
javascript DOM操作之 querySelector,querySelectorAll
- javaScript DOM JQuery AJAX
http://www.cnblogs.com/wupeiqi/articles/5369773.html 一 JavaScript JavaScript是一门编程语言,浏览器内置了JavaScript ...
- JavaScript : DOM文档解析详解
JavaScript DOM 文档解析 1.节点(node):来源于网络理论,代表网络中的一个连接点.网络是由节点构成的集合 <p title=“a gentle reminder”> ...
随机推荐
- 89-Relative Vigor Index 相对活力指数指标.(2015.7.4)
Relative Vigor Index 相对活力指数指标 ~计算: RVI = (CLOSE-OPEN)/(HIGH-LOW) RVIsig=SMA(RVI,N) ~思想: 牛市中,收盘>开盘 ...
- Linux 搭建 squid 代理服务器 三种模式
CentOS 6.7 squid 代理服务器 一般有两张或以上网卡,一张链接公网,访问外网资源,一张位于局域网. 代理服务器可以提供文件缓存.复制和地址过滤等服务,充分利用有限的出口带宽,加快内部主机 ...
- Oracle 实现查询不区分大小写(设置数据库)
转http://blog.csdn.net/shl7765856/article/details/7622756 查询数据的时候. SQL Server 默认 不区分大小写. 如果要区分,就要额外的设 ...
- 拥抱变革(More Fearless Change)
今天从大敏捷群中了解到Tid2017的一个讲演,一位敏捷教练,组织变革的专著的作者Linda的讲演. <More Fearless Change-Strategy for Making Your ...
- 【07】Ajax status和statusText状态对照表
Ajax status和statusText状态对照表 XMLHttpRequest 对象的 status 和 statusText 属性保存有服务器返回的 http 状态码,不同的是,statu ...
- Wireshark抓包工具的简单使用1(界面介绍)
Wireshark安装完成后,就可以打开,具体运行界面如下 一.菜单——用于开始操作 File ——包括打开.合并捕捉文件,save/保存,Print/打印,Export/导出捕捉文件的全部或部分.以 ...
- htmlspecialschars与htmlentities的区别
根据php手册,htmlentities与htmlspecialchars功能几乎是一模一样.唯一的差别就是,对于无效的代码单元序列(通俗讲就是不认识的编码)是否进行编码.htmlentities会进 ...
- POJ 2104 K-th Number (可持久化线段树)
题目大意 给一个长度为n的序列,有m个询问,每次询问一个区间里面第k小的数. 解题分析 静态的区间第k大.复习了一下可持久化线段树. 首先对数值离散化,建一颗权值线段树.按照序列的顺序依次插入,每一个 ...
- Linux下汇编语言学习笔记27 ---
这是17年暑假学习Linux汇编语言的笔记记录,参考书目为清华大学出版社 Jeff Duntemann著 梁晓辉译<汇编语言基于Linux环境>的书,喜欢看原版书的同学可以看<Ass ...
- Uva - 12230 Crossing Rivers (数学期望)
你住在村庄A,每天需要过很多条河到另一个村庄B上班,B在A的右边,所有的河都在A,B之间,幸运的是每条船上都有自由移动的自动船, 因此只要到达河左岸然后等船过来,在右岸下船,上船之后船的速度不变.现在 ...