document,element,dom对象api详解
Document对象:
- 根元素的访问,也就是HTML标签的访问。使用document.documentElement访问根对象。
- 使用Document对象查找对象
- getElementById():通过节点的id属性,查找对应节点。
- getElementsByName():通过节点的name属性,查找对应节点。
- getElementsByTagName():通过节点名称,查找对应节点。
- 使用Document对象的方法创建节点:
- crateElement(tagName):创建元素节点。
- createTextNode(data):创建文本节点。
- createAttirbute(name):创建属性节点。(不使用)
Element对象:
- 操作Element对象的属性:
- 获取属性:getAttribute(name);方法
- 设置属性:setAttribute(name,value)方法。
- 删除属性:removeAttribute(name);方法。
- 在Element对象中查找Element对象:
- 在Element对象的范围内,可以用来查找其他节点的唯一有效方法就是getElementsByTagName()方法。而该方法返回的是一个集合。
Element对象的一个案例:
- 在一个<ul></ul>标签下创建一个li标签
- <body>
- <ul id="city">
- <li id="bj" name="beijing">北京</li>
- <li id="tj" name="tianjin">天津</li>
- </ul>
- <script type="text/javascript">
- //创建一个标签元素
- var liElment = document.createElement("li");
- //创建一个文本节点
- var textElement = document.createTextNode("上海");
- //将文本节点加到标签元素下面
- liElment.appendChild(textElement);
- //为标签元素创建属性
- liElment.setAttribute("id","sh");
- liElment.setAttribute("name","Shanghai");
- //将标签元素加到ul标签下
- document.getElementById("city").appendChild(liElment);
- </script>
- </body>
Node对象包含:
- 节点名称,值和类型。
- 父节点,子节点和同辈节点。
- 节点属性
- 检测子节点和属性。
- 操纵Dom节点树。
- 复制和移动节点。
节点名称,值和类型:
- nodeName:其内容就是给节点的名称。
- 如果是元素节点,nodeName返回这个元素的名称。
- 如果是属性节点,nodeName返回这个属性的名称。
- 如果是文本节点,nodeName返回这个内容为#text的字符串。
- nodeType:返回一个整数,这个数值代表给点节点的类型。
- Node.ELEMENT_NODE:1,元素节点。
- Node.ATTRIBUTE_NODE:2,属性节点。
- Node.TEXT_NODE:3,文本节点
- nodeValue:返回给定节点的当前值(字符串):
- 如果给定节点是一个元素节点:返回null。
- 如果给定节点是一个属性节点:返回属性的值。
- 如果给定节点时一个文本节点:返回文本节点的内容。
- 下面是使用的示例:
- <body>
- <ul id="city">
- <li id="bj" name="beijing">北京</li>
- <li id="tj" name="tianjin">天津</li>
- </ul>
- <p>
- 你好
- </p>
- <script type="text/javascript">
- var bj = document.getElementById("bj");
- //元素节点
- // alert(bj.nodeName);//li
- // alert(bj.nodeType);//1
- // alert(bj.nodeValue);//null
- //属性节点
- // var name = bj.getAttributeNode("name")
- // alert(name.nodeName); //name
- // alert(name.nodeType); //2
- // alert(name.nodeValue); //beijing
- var p = document.getElementsByTagName("p")[0];
- var text = p.childNodes[0];
- alert(text.nodeName);//#text
- alert(text.nodeType);//3
- alert(text.nodeValue);//你好
- </script>
- </body>
父节点,子节点和同辈节点:
- 父节点:parentNode:
- parentNode返回的永远都是一个节点,因为只有元素节点才有可能包含子节点。
- document节点没有父节点。也就是文档节点没有父节点,也就是HTML
- 子节点:childNode:
- childNodes,获取指定节点的所有子节点。其实上个例子已经使用了。
- firstChild:指定第一个子节点。
- lastChild:指定最后一个子节点。
- 同辈节点:
- nextSibling:返回一个给定节点的下一个兄弟节点。
- previousSibling:返回一个节点的上一个兄弟节点。
- 示例如下:
- <body>
- <ul id="city">
- <li id="bj" name="beijing">北京</li>
- <li id="tj" name="tianjin">天津</li>
- </ul>
- <p>你好</p><input type="text">
- <script type="text/javascript">
- //获取p标签的父,子,兄节点
- var p = document.getElementsByTagName("P")[0];
- alert(p.parentNode);//body
- alert(p.childNodes[0].nodeValue)//你好
- alert(p.previousSibling.nodeValue)//空格,说明空格也会作为一个节点
- alert(p.nextSibling.nodeName);//input。这里就没出现空格,就是input节点
- </script>
- </body>
节点属性:
- 节点属性attributes是Node接口定义的属性。
- 节点属性attributes就是节点的属性(特别是元素节点)的属性。
- 事实上,attributes中包含的是一个节点所有属性的集合。
- attributes.getNameItem()和Element元素的getAttribute()方法很相似。
- <body>
- <ul id="city">
- <li id="bj" name="beijing">北京</li>
- <li id="tj" name="tianjin">天津</li>
- </ul>
- <script type="text/javascript">
- var bj = document.getElementById("bj");
- alert(bj.attributes[1].nodeValue);
- </script>
- </body>
检测子节点和属性
- 查看是否有子节点:hasChildNodes();
- 查看是存在属性:hasAttributes();
- 即使节点中没有定义属性,其attributes属性还是有效的,而且长度是0。同样childNodes属性也是如此。
- 当你想知道某个节点是否包含子节点或属性时,使用hasChildNodes(),hasAttributes()。如果想知道包含多少个:attributes和childNodes属性。
- 在IE中不存在hasAttributes();方法。(不使用)
- 示例如下:
- <body>
- <input type="text" id="username" value="username">
- <p>
- 明天休息
- </p>
- <script type="text/javascript">
- // var username = document.getElementById("username");
- // alert(username.hasChildNodes());//false
- // alert(username.hasAttribute());//无效果
- var p = document.getElementsByTagName("p")[0];
- alert(p.hasChildNodes());//true
- </script>
- </body>
操作Dom节点数:
- 插入节点:
- appendChild()方法。
- insertBefore()方法。
- 没有insertAfter()方法。
- 删除节点:
- removeChild()方法。
- 替换节点:
- replaceChild()
- 示例
- <body>
- <ul id="city">
- <!--注意这里不要回车-->
- <li id="bj" name="beijing">北京</li><li id="tj" name="tianjin">天津</li>
- </ul>
- <script type="text/javascript">
- //创建<li id="sh" name="shanghai">上海</li>节点,增加到天津节点的前面
- // var liElement = document.createElement("li");
- // liElement.appendChild(document.createTextNode("上海"));
- // liElement.setAttribute("id","sh");
- // liElement.setAttribute("name","shanghai");
- // liElement.insertBefore(document.getElementById("tj"));
- // document.getElementById("city").appendChild(liElement);
- //<li id="sh" name="shanghai">上海</li>节点插入北京节点的后面,没有insertAfter()方法。
- var liElement = document.createElement("li");
- liElement.appendChild(document.createTextNode("上海"));
- liElement.setAttribute("id","sh");
- liElement.setAttribute("name","shanghai");
- var bjElement = document.getElementById("bj")
- //得到兄弟节点
- var nextElement = bjElement.nextSibling;
- liElement.insertBefore(nextElement);
- //添加到city下面
- document.getElementById("city").appendChild(liElement);
- </script>
- </body>
复制和移动节点:
- 复制节点:cloneNode(boolean)方法,其中boolean参数是判读是否复制子节点。
- 移动节点:由三种方法组合完成:
- 查找节点:
- getElementById();通过节点id属性,查找对应节点。
- getElementsByName();通过节点名称,查找对应节点。
- getElementsByTagName();通过节点名称,查找对应节点。
- 插入节点:
- insertBefore()方法
- appendChild()方法。
- 替换节点:
- replaceChild()方法。
- 查找节点:
- 示例代码如下:
- <body>
- <ul id="city">
- <li id="bj" name="beijing">北京</li>
- <li id="tj" name="tianjin">天津</li>
- </ul>
- lt;ul id="game">
- <li id="fk" name="fankong">反恐精英</li>
- <li id="xj" name="xingji">星际</li>
- </ul>
- lt;script type="text/javascript">
- //当点击北京节点,就和反恐精英替换
- document.getElementById("bj").onclick = function(){
- //得到北京节点
- var bjElement = document.getElementById("bj");
- //得到反恐精英
- var fkElemet = document.getElementById("fk");
- //这里也可以:this.parentNode.replaceChild(fkElemet,bjElement);
- bjElement.parentNode.replaceChild(fkElemet,bjElement);
- }
- lt;/script>
- </body>
复制案例:
- <body>
- <input type="button" id="login" value="登陆">
- <p>
- 按钮来这:
- </p>
- <script type="text/javascript">
- document.getElementById("login").onclick = function(){
- var loginElement = document.getElementById("login");
- //也可以写成:var copy = this.cloneNode(true);
- var copy = loginElement.cloneNode(true);
- var pElemet = document.getElementsByTagName("p")[0];
- pElemet.appendChild(copy);
- }
- </script>
- </body>
document,element,dom对象api详解的更多相关文章
- [总结]JS操作DOM常用API详解
文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...
- jquery对象和DOM对象的相互转换详解
jquery对象和DOM对象的相互转换 在讨论jquery对象和DOM对象的相互转换之前,先约定好定义变量的风格如果获取的是jquery对象,那么在变量前面加上$,例如 var $varible = ...
- HTML5 FileReader读取Blob对象API详解
使用FileReader对象,web应用程序可以异步的读取存储在用户计算机上的文件(或者原始数据缓冲)内容,可以使用File对象或者Blob对象来指定所要读取的文件或数据.其中File对象可以是来自用 ...
- DOM API详解
来源于:http://zxc0328.github.io/2016/01/23/learning-dom-part1/ https://zxc0328.github.io/2016/01/26/lea ...
- hibernate学习(2)——api详解对象
1 Configuration 配置对象 /详解Configuration对象 public class Configuration_test { @Test //Configuration 用户 ...
- javascript event(事件对象)详解
javascript event(事件对象)详解 1. 事件对象 1. 事件对象 Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 什 ...
- canvas绘图API详解
canvas绘图API详解 1.context的状态 矩阵变换属性 当前剪辑区域 context的其他状态属性: strokeStyle, fillStyle, globalAlpha, lineWi ...
- jqGrid APi 详解
jqGrid APi 详解 jqGrid皮肤 从3.5版本开始,jqGrid完全支持jquery UI的theme.我们可以从http://jqueryui.com/themeroller/下载我们所 ...
- 百度地图API详解之事件机制,function“闭包”解决for循环和监听器冲突的问题:
原文:百度地图API详解之事件机制,function"闭包"解决for循环和监听器冲突的问题: 百度地图API详解之事件机制 2011年07月26日 星期二 下午 04:06 和D ...
随机推荐
- java synchronized 关键字原理
Synchronized 关键字是解决并发问题常用解决方案,有以下三种使用方式: 同步普通方法,锁的是当前对象.同步静态方法,锁的是当前 Class 对象.同步块,锁的是 {} 中的对象. 实现原理: ...
- MapReduce清洗日志数据统计PV量
package mapreduce.webpv; import java.io.IOException; import org.apache.commons.lang.StringUtils; imp ...
- C Mingw gcc printf 刷新缓冲行
C Mingw gcc printf 刷新缓冲行 参考:https://stackoverflow.com/questions/13035075/printf-not-printing-on-cons ...
- Lucene第一讲——概述与入门
一.概述 1.什么是Lucene? Lucene是apache下的一个开源的全文检索引擎工具包. 它为软件开发人员提供一个简单易用的工具包(类库),以方便的在目标系统中实现全文检索的功能. 2.能干什 ...
- SpringBoot学习:整合shiro(验证码功能和登录次数限制功能)
项目下载地址:http://download.csdn.NET/detail/aqsunkai/9805821 (一)验证码 首先login.jsp里增加了获取验证码图片的标签: <body s ...
- 聊聊WS-Federation(test)
本文来自网易云社区 单点登录(Single Sign On),简称为 SSO,目前已经被大家所熟知.简单的说, 就是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. 举例: 我们 ...
- eclipse导入jmeter3.1源码并运行
jmeter3.1源码地址:https://archive.apache.org/dist/jmeter/source/ 1.打开eclipse,新建一个java project的项目,并点击next ...
- 你的APK安全吗?来WeTest免费测!
腾讯安全联合实验室就曾在<2018上半年互联网黑产研究报告>指出,移动端黑产规模宏大,恶意推广日均影响用户超过千万. 尤其在网络强相关的APP流行年代,当APP应用客户端上传与获取信息,大 ...
- 浅析JVM内存区域及垃圾回收
一.JVM简介 JVM,全称Java Virtual Machine,即Java虚拟机.以Java作为编程语言所编写的应用程序都是运行在JVM上的.JVM是一种用于计算设备的规范,它是一个虚构出来的计 ...
- hdu1159Common Subsequence(动态规划)
Common Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...