DOM(JavaScript高程笔记)
一、节点层次
1.Node类型
if (someNode.nodeType == 1){ // 适用于所有浏览器
alert("Node is an element.");
}
- Node.ELEMENT_NODE (1);
- Node.ATTRIBUTE_NODE (2);
- Node.TEXT_NODE (3);
nodeName 和 nodeValue 属性
在使用这两个值以前,最好是像下面这样先检测一下节点的类型。
if (someNode.nodeType == 1){
value = someNode.nodeName; // nodeName 的值是元素的标签名
// 对于元素节点,nodeName 中保存的始终都是元素的标签名,而 nodeValue 的值则始终为 null 。
}
节点关系
每个节点都有一个 childNodes 属性,其中保存着一个 NodeList 对象。
NodeList 是一种类数组对象,它实际上是基于 DOM 结构动态执行查询的结果。
// 转为数组
function convertToArray(nodes){
var array = null;
try {
array = Array.prototype.slice.call(nodes, 0);
} catch (ex) {
// IE8 及更早版本将 NodeList实现为一个 COM 对象
array = new Array();
for (var i=0, len=nodes.length; i < len; i++){
array.push(nodes[i]);
}
}
return array;
}
convertToArray(someNode.childNodes);
- childNodes
- parentNode
- previousSibling
- nextSibling
- firstChild
- lastChild
- hasChildNode() // 在节点包含一或多个子节点的情况下返回 true
- ownerDocument // 所有节点都有的属性,指向整个文档节点
操作节点
- appendChild() // 如果节点已经是文档的一部分,则将该节点从原来的位置
转移到末尾 - insertBefore() // 如果参照节点是
null ,则 insertBefore() 与 appendChild() 执行相同的操作 - replaceChild()
- removeChild()
- cloneNode() // IE会复制JavaScript事件,最好先移除事件
- normalize() // 处理文本节点,空则删,相邻则合并
3.Document类型
- nodeType = 9
- nodeName = '#document'
- nodeValue = null
- parentNode = null
- ownerDocument = null
其子节点可能是一个 DocumentType (最多一个) 、 Element (最多一个) 、 ProcessingInstruction
或 Comment 。
文档的子节点
- documentElement // 指向<html>
- childNodes[0] // 指向<html>
- body // 指向<body>
- doctype // 指向<!DOCTYPE>,各浏览器支持不一致
文档信息
- title // 中的文本
- URL
- referrer // 来源页面
- domain
1 不能将这个属性设置为 URL 中不包含的域
// 假设页面来自 p2p.wrox.com 域
document.domain = "wrox.com"; // 成功
document.domain = "nczonline.net"; // 出错!
2 如果域名一开始是“松散的” (loose) ,那么不能将它再设
置为“紧绷的” (tight) 。
// 假设页面来自于 p2p.wrox.com 域
document.domain = "wrox.com"; //松散的(成功)
document.domain = "p2p.wrox.com"; //紧绷的(出错!)
3 设置为相同的值可用于 frame 跨域
查找元素
- getElementById()
- getElementsByTagName() // 返回 HTMLCollection 对象
- getElementsByName() // 返回 HTMLCollection 对象
特殊集合 // 返回值与 HTMLCollection 对象类似
HTMLCollection对象
- namedItem() // 通过元素的 name 属性取得集合中的项(只会取得第一项)
- 我们可以向方括号中传入数值或字符串形式的索引值。在后台,对数
值索引就会调用 item() ,而对字符串索引就会调用 namedItem() 。
DOM一致性检测
document.implementation.hasFeature('name', 'verson');
文档写入
// 直接写入文档末尾
document.write("<strong>" + (new Date()).toString() + "</strong>");
// 如果在文档加载结束后再调用 document.write() ,那么输出的内容将会重写整个页面
window.onload = function(){
document.write("Hello world!");
};
- write() // 原样写入
- writeIn() // 末尾添加换行符(\n)
- open()
- close() // 打开、关闭输出流,如页面加载期间用 write 和 writeIn 则无需打开关闭
3.Element类型
- nodeType = 1
- nodeName = tagName = 标签名
- nodeValue = null
取得属性
- getAttribute() // 可取得 data- 自定义属性。
- 可以通过 DOM 对象的属性来取得非自定义属性。
- IE 可以通过 DOM 对象属性取得自定义属性。
1 style
- getAttribute() 访问返回CSS文本
- DOM 对象属性访问返回对象
2 事件(onclick)
- getAttribute() 访问返回字符串
- DOM 对象属性访问返回函数
设置属性
- setAttribute() // 可设置 data- 自定义属性
- 可以通过 DOM 对象的属性来设置非自定义属性。
- IE 可以通过 DOM 对象属性设置自定义属性。
删除属性
- removeAttribute() // 彻底删除,包括属性和值
attributes属性
attributes 属性中每一个元素属性都由一个 Attr 节点表示,保存在一个 NamedNodeMap 对象中 ,NamedNodeMap 与 NodeList 类似。
节点属性
- nodeName
- nodeValue
遍历元素属性
function outputAttributes(element){
var pairs = new Array(),
attrName,
attrValue,
i,
len;
for (i=0, len=element.attributes.length; i < len; i++){
attrName = element.attributes[i].nodeName;
attrValue = element.attributes[i].nodeValue;
if (element.attribute[i].specified) {
pairs.push(attrName + "=\"" + attrValue + "\"");
}
}
return pairs.join(" ");
}
创建元素
var div = document.createElement("div");
// 在 IE 中可用以下方式
var div = document.createElement("<div id=\"myNewDiv\" class=\"box\"></div >");
DOM(JavaScript高程笔记)的更多相关文章
- JAVASCRIPT高程笔记-------第十章 DOM对象
10.1.1 node类型 --除IE外 所有浏览器都可以访问到这个类型 :JS中所有的节点类型都继承自Node类型 nodeName 与nodeValue 如果是一个元素 那么nodeName中保 ...
- javaScript高程笔记--最佳实践
1.可维护性 <1>什么是可维护的代码 (1)可理解性 (2)直观性 (3)可适应性 (4)可扩展性 (5)可调试性 <2>代码约定 (1)可读性---适当的进行注释[函数和方 ...
- JAVASCRIPT高程笔记-------JSON与AJAX
json对象——语法 简单值:与JS相同语法,可以是字符串,数值,布尔值,null:但不支持undefined 对象: 复杂数据类型,表示一组有序的键值对,键值对的值可以是简单数据,也可以是复杂数据 ...
- JAVASCRIPT高程笔记-------第五章 引用类型
一.Object类型 1.1创建方式 ①new关键字 : var person = new Oject(); ②给定直接量: var person = { name : "zhangsan& ...
- 函数表达式(JavaScript高程笔记)
函数声明 特点:函数声明提升(执行代码之前解析器会先读取函数声明,并使其在执行任何代码之前可用,意味着可以把函数声明放在调用语句之后) function functionName(arg0,arg1) ...
- javascript高程笔记:逻辑与和逻辑或
逻辑与和或 逻辑与 当 && 前后两个操作数都是布尔值,无可厚非,同时为true才为true.与其他强类型语言不同的是,javascript逻辑与前后的操作数可以应用于任何类型. 而且 ...
- javascript高程笔记-------第四章 变量、作用域和内存问题
首先JavaScript中的变量分为基本类型和引用类型. 基本类型就是保存在栈内存中的简单数据段,而引用类型指的是那些保存在堆内存中的对象. 1.参数传递 javascript中所有参数的传递都是值传 ...
- BOM(JavaScript高程笔记)
再次编辑于20160115 一.window对象 双重角色 JS访问浏览器窗口的接口 ECAMAscript规定的Global对象 1.全局作用域 所有在全局作用域中声明的变量.函数都会变成windo ...
- JAVASCRIPT高程笔记-------第八章 浏览器BOM对象
8.1 window对象--表示一个浏览器的实例 在全局作用域中声明的任何变量.函数都会变成window对象的属性和方法,与之直接定义window对象的属性的区别是 window.xxx 可以通过 ...
随机推荐
- 一次对路边饮用水RFID供应机的跑路玩法
"如何成为一个合格的硬件白帽子? 答案: 一个有聪明大脑的你 要有归纳类比和善于用GOOGLE的能力(百度?放弃吧) 善于翻阅和查询相关开发文档和强大的跑路能力." WARNING ...
- python 多版本管理pyenv和virtualenv虚拟开发环境
pyenv是管理多个python版本的工具. 1.pyenv的安装 git clone https://github.com/yyuu/pyenv.git ~/.pyenv 2.将PYENV_ROOT ...
- [Umbraco] 熟悉管理页面
登录到umbraco管理界面后,发现其后台管理页很简洁 首页看到左侧部分是一个Content和Sections,右侧是管理区域 介绍各个Sections代表的含义: "Content&quo ...
- 课程一(Neural Networks and Deep Learning),第四周(Deep Neural Networks)——2.Programming Assignments: Building your Deep Neural Network: Step by Step
Building your Deep Neural Network: Step by Step Welcome to your third programming exercise of the de ...
- Hadoop框架之HDFS的shell操作
既然HDFS是存取数据的分布式文件系统,那么对HDFS的操作,就是文件系统的基本操作,比如文件的创建.修改.删除.修改权限等,文件夹的创建.删除.重命名等.对HDFS的操作命令类似于Linux的she ...
- 剑指offer八之跳台阶
一.题目 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 二.思路 a.如果两种跳法,1阶或者2阶,那么假定第一次跳的是一阶,那么剩下的是n-1个台阶,跳法 ...
- WebFlux基础之响应式编程
上篇文章,我们简单的了解了WebFlux的一些基础与背景,并通过示例来写了一个demo.我们知道WebFlux是响应式的web框架,其特点之一就是可以通过函数式编程方式配置route.另外究竟什么是响 ...
- MyBatis中如何一次执行多条语句(使用mysql数据库)
解决办法不外乎有三个:1.多条sql分批执行:2.存储过程或函数调用:3.sql批量执行. MyBatis中如何一次执行多条语句(使用mysql数据库): 1.修改数据库连接参数加上allowMult ...
- Java总结:字符串详解
更新时间:2018-1-6 21:20:39 更多请查看在线文集:http://android.52fhy.com/java/index.html String 字符串创建 String str1=& ...
- xshell 登陆堡垒机实现自动跳转
1, 正常使用用户密码登录堡垒机并保存登陆配置 2, 配置登陆脚本 添加第一个: expect 为空send :ssh root@ip 添加第二个: expect root@ip's password ...