读javascript高级程序设计10-DOM
一、节点关系
元素的childNodes属性来表示其所有子节点,它是一个NodeList对象,会随着DOM结构的变化动态变化。
- hasChildNodes():是否有子节点。
var headlines=document.getElementById("headline_block");
var childs=headlines.childNodes;
childs.length;//
childs[0];//取第一个子节点
childs.item(0);//取第一个子节点
- parentNode:指向其DOM树中的父节点;
- previousSibling:当前节点前面相邻的兄弟节点;
- nextSibling:当前节点后面相邻的兄弟节点。
var li1=childs[0].childNodes[2];
li1.previousSibling;
li1.nextSibling;
二、节点操作
1.appendChild():向节点的childNodes末尾追加一个节点。如果传入的节点已经是其子节点,那么会将该节点移动到末尾。
var headlines=document.getElementById("headline_block");
var ul=headlines.childNodes[0];
var firstnode=ul.firstChild
ul.appendChild(firstnode);
2.insertBefore(newnode,somenode):向指定位置来插入子节点。第一个参数是要插入的节点,第二个是作为参照的节点。
var headlines=document.getElementById("headline_block");
var ul=headlines.childNodes[0];
var firstnode=ul.firstChild;
ul.insertBefore(firstnode,ul.childNodes[2]);
3.replaceChild(newnode,oldnode):替换节点。第一个参数是要插入的新节点,第二个参数是要被替换掉的节点。
4.removeChild(somenode):移除节点指定节点。
var headlines=document.getElementById("headline_block");
var ul=headlines.childNodes[0];
ul.removeChild(ul.childNodes[0]);
常用Node类型
三、Document类型(nodeType=9)
1. 基本属性
- nodeType=9
- nodeName="#document"
- document.documentElement:指向页面中的html元素;
- document.body:指向body元素。
2. 文档信息:
document.title:获取或修改页面title,修改后会反映在浏览器标签页上,但是不会修改<title>元素。
document.title;//"博客园 - 开发者的网上家园"
document.title="博客园-小静";
document.URL:显示页面完整的URL。
document.referrer:来源页面的完整地址。
document.domain:页面的域名,该属性是可以设置的。但要注意几点:
- 不能将domain设置为当前所在域名中不包含的域;
- 不能将松散的域再设置为紧绷的域;
- 跨域通信:由于跨域安全限制,不用域的页面之间是无法进行javascript通信的。通过将两个页面的document.domain设置为相同值,就可以互相访问对方包含的javascript对象了。
例如当前在博客园闪存主页:
document.URL;//"http://home.cnblogs.com/ing/"
document.referrer;//"http://www.cnblogs.com/"
document.domain;//"home.cnblogs.com"
document.domain="www.baidu.com";//报错
document.domain="cnblogs.com";//可以
document.domain="home.cnblogs.com";//报错
document.domain;//"cnblogs.com"
3. 特殊集合
- document.anchors:带name特性的<a>签;
- document.links:带链接的<a>签;
- document.images:页面中所有<img>元素。
四、Element类型(nodeType=1)
Element类型提供了对标签名、子节点、特性的访问和操作。
1.标签名
tagName返回的是标签名大写格式,比较时要先进行大小写转换。
node.tagName.toLowerCase()=="a";
2.HTML元素基本特性className:与元素的class特性对应,用于指定元素的css样式。
3.元素属性
- getAttribute():获取元素的某个特性。这里的特性名与元素实际的特性相同,所以想获得样式名就直接使用“class”而不是“clssName”。
- setAttribute(attr,value):设置元素特性。第一个参数是特性名称,第二个参数是特性的值。使用该方法设置的特性名称会自动转换为小写。
- removeAttribute(attr):彻底移除元素的某个属性。
五、Text类型(nodeType=3)
1. nodeName="#text"
2. 获取节点文本内容:nodeValue或者data属性均可。
3. 操作文本节点内容
- appendData(text):在文本节点末尾追加文本。
- deleteData(offset,count):从offset位置开始删除count个字符。
- insertData(offset,text):从offset位置插入文本text。
- replaceData(offset,count,text):用text替换从offset位置开始长度为count的文本。
- substringData(offset,count):提取从offset位置开始长度为count的文本。
- splitText(offset):从指定位置将文本节点分割为两个文本节点。
4. normalize():规范化文本节点。在包含多个文本节点的元素上调用该方法,会将其文本节点进行合并。
var node=document.getElementById("ing_body_578997");
//获取文本节点
var textnode=node.childNodes[0];
//获取节点文本值
var data=textnode.data;//"最近学js高级编程,又是基础书,该掉粉了,`(*∩_∩*)′"
//追加文本
textnode.appendData("Text");//最近学js高级编程,又是基础书,该掉粉了,`(*∩_∩*)′Text
//删除文本片段
textnode.deleteData(8,10);//最近学js高级编粉了,`(*∩_∩*)′Text
//插入文本
textnode.insertData(8,"博客园");//最近学js高级编博客园粉了,`(*∩_∩*)′Text
//替换文本
textnode.replaceData(5,25,',加油');//最近学js加油
//获取文本片段
textnode.substringData(5,1);//,
//分割为多个节点
textnode.splitText(',');
console.log(node.childNodes.length);//
//规范化
node.normalize();
console.log(node.childNodes.length);//
六、DocumentFragment类型(nodeType=11)
可以作为仓库使用,保存未来要添加到文档中的节点。
(function(){
var ul=document.getElementById("myList");
var frag=document.createDocumentFragment();
var li=null,text=null;
for(var i=4;i<=6;i++){
li=document.createElement("li");
text=document.createTextNode("item"+i);
li.appendChild(text);
frag.appendChild(li);
}
ul.appendChild(frag);
})();
七、DOM操作
1.动态脚本
①通过src包含外部脚本文件。加载完成后就可以在页面其他地方调用了。
function LoadScriptSrc(src){
var script=document.createElement("script");
script.type="text/javascript";
script.src=src;
document.body.appendChild(script);
}
LoadScriptSrc("validate.js");
checkName();
②动态添加行内代码脚本。代码作用域为全局,而且执行完后立马可用。
function LoadScript(){
var script=document.createElement("script");
script.type="text/javascript";
try{
script.appendChild(document.createTextNode("function begin(){console.log('hello world.')}"));
}catch(ex){
script.text="function begin(){console.log('hello world.')}";
}
document.body.appendChild(script);
}
LoadScript();
begin();
2.动态样式
注意样式要添加到head中。
①使用Link动态添加来自外部的样式文件,执行是异步的。
function loadCss(url){
var link=document.createElement("link");
link.rel="stylesheet";
link.href=url;
var head=document.getElementsByTagName("head")[0];
head.appendChild(link);
}
loadCss("http://www.damifanli.com/data/css/index_index_914724003.css")
②使用style动态添加嵌入式CSS样式代码。向页面中添加样式后立即就能看到效果。
function loadCss(css){
var style=document.createElement("style");
style.type="text/css";
try{
style.appendChild(document.createTextNode(css));
}catch(ex){
style.styleSheet.cssText=css;
}
var head=document.getElementsByTagName("head")[0];
head.appendChild(style);
}
loadCss("body{background-color:red}");
读javascript高级程序设计10-DOM的更多相关文章
- 读javascript高级程序设计00-目录
javascript高级编程读书笔记系列,也是本砖头书.感觉js是一种很好上手的语言,不过本书细细读来发现了很多之前不了解的细节,受益良多.<br/>本笔记是为了方便日后查阅,仅作学习交流 ...
- 读javascript高级程序设计-目录
javascript高级编程读书笔记系列,也是本砖头书.感觉js是一种很好上手的语言,不过本书细细读来发现了很多之前不了解的细节,受益良多.<br/>本笔记是为了方便日后查阅,仅作学习交流 ...
- 读javascript高级程序设计08-引用类型之Global、Math、String
一.Global 所有在全局作用域定义的属性和方法,都属于Global对象. 1.URI编码: encodeURI():主要用于对整个URI编码.它不会对本身属于URI的特殊字符进行编码. encod ...
- JavaScript高级程序设计-10.11: DOM及其扩展
什么是DOM? DOM(文档对象模型)是针对 HTML 和 XML 文档的一个 API(应用程序编程接口).DOM描绘了一个层次化的节点树,允许开发人员添加.移除和修改页面的某一部分. 文档节点(do ...
- 读javascript高级程序设计01-基本概念、数据类型、函数
一. javascript构成 1.javascript实现由三部分组成: ECMAScript:核心语言功能 DOM:文档对象模型,提供访问和操作网页内容的方法和接口 BOM:浏览器对象模型,提供与 ...
- 《JAVASCRIPT高级程序设计》DOM扩展
虽然DOM为XML及HTML文档交互制定了一系列的API,但仍然有几个规范对标准的DOM进行了扩展.这些扩展中,有很多是浏览器专有的,但后来成了事实标准,于是其他浏览器也提供了相同的实现:浏览器开发商 ...
- 读javascript高级程序设计02-变量作用域
一. 延长作用域链 有些语句可以在作用域前端临时增加一个变量对象,该变量对象在代码执行完成后会被移除. ①with语句延长作用域. function buildUrl(){ var qs=" ...
- 读javascript高级程序设计12-HTML5脚本编程
一.跨文档消息传递(XDM) 1.发送消息 postMessage(msg,domain)用于发送跨文档消息.第一个参数是要传递的消息内容,第二个参数表示接收方来自哪个域.第二个参数有助于提高安全性, ...
- 读javascript高级程序设计13-JSON
JSON是一个轻量级的数据格式,可以简化表示数据结构的工作量.在实际工作中,我们经常用它来传递数据,不过对于其使用的一些细节还是需要注意的.在ECMAScript5中定义了原生的JSON对象,可以用来 ...
随机推荐
- 对hashmap与hashcode()、equals()的理解
1.equals方法没被重写的时候 比较的只是对象的地址 重写之后 比较的才是对象里的内容 2.重写equals的时候 务必需要重写hashcode 不然在用到容器的时候 会出现问题 因为容器会 ...
- 响应式布局1--媒体查询和-webkit-min-device-pixel-ratio
-webkit-min-device-pixel-ratio其实就是这个玩意 window.devicePixelRatio是设备上物理像素和设备独立像素(device-independent pix ...
- SQL语法粗整理
1.在同一张表中,对前一条数据进行更新性插入操作,即:
- Oracle中的自动增长字段
Oracle中的自动增长字段 Oracle 中不像MYSQL 和MSSQLServer 中那样指定一个列为自动增长列的方式,不过在Oracle中可以通过SEQUENCE序列来实现自动增长字段. 在Or ...
- 深入理解Android之Gradle
深入理解Android之Gradle 格式更加精美的PDF版请到:http://vdisk.weibo.com/s/z68f8l0xTYrZt 下载 Gradle是当前非常"劲爆" ...
- Lucene学习总结
在使用Lucene前,我们先大致熟悉下Lucene的几个核心类. 核心索引类: public class IndexWriter 索引过程的中心组件,把它想象成一个可以对索引进行写操作的对象. pub ...
- LINK : fatal error LNK1104: 无法打开文件“LIBCD.lib”
出现这类问题一般是由于所运行的项目是VC6(或者vs2003)创建的,而后又用VS2005或者更高版本工具打开项目导致的,原因都是因为LIBCD.lib文件被更改了.要解决问题的话,只要在链接设置那里 ...
- css3 calc()方法详解
calc()对大家来说,或许很陌生,不太会相信calc()是css中的部分.因为看其外表像个函数,既然是函数为何又出现在CSS中呢?这一点也让我百思不得其解,今天有一同事告诉我,说CSS3中有一个属性 ...
- Android安全研究经验谈
安全研究做什么 从攻击角度举例,可以是:对某个模块进行漏洞挖掘的方法,对某个漏洞进行利用的技术,通过逆向工程破解程序.解密数据,对系统或应用进行感染.劫持等破坏安全性的攻击技术等. 而防御上则是:查杀 ...
- 滚动RollUp、压缩
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...