读javascript高级编程10-DOM

一、节点关系

元素的childNodes属性来表示其所有子节点,它是一个NodeList对象,会随着DOM结构的变化动态变化。

  • hasChildNodes():是否有子节点。
var headlines=document.getElementById("headline_block");
var childs=headlines.childNodes;
childs.length;//1
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);//2
//规范化
node.normalize();
console.log(node.childNodes.length);//1

六、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

时间: 2024-10-10 19:58:53

读javascript高级编程10-DOM的相关文章

读javascript高级编程11-事件

一.事件流 事件流指从页面中接收事件的顺序. 1.事件冒泡(常用) IE中采用的事件流是事件冒泡,先从具体的接收元素,然后逐步向上传播到不具体的元素. 2.事件捕获(少用) Netscapte采用事件捕获,先由不具体的元素接收事件,最具体的节点最后才接收到事件. 3.DOM事件流 DOM2级事件包括三个阶段:事件捕获阶段.处于目标阶段和事件冒泡阶段. 二.事件处理程序 事件处理程序就是响应某些事件的函数,如onclick等. 1. DOM0级事件处理程序 每个元素都有自己的事件处理程序属性,如o

读javascript高级编程02-变量作用域

一. 延长作用域链 有些语句可以在作用域前端临时增加一个变量对象,该变量对象在代码执行完成后会被移除. ①with语句延长作用域. function buildUrl(){ var qs="?debug=true"; with(location){ var url=href+qs; } return url; } buildUrl(); //result:http://www.fanxbao.com/?debug=true ②try...catch...中的catch语句块延长作用域链

读javascript高级编程07-引用类型、Object、Array

一.引用类型 ECMAScript是支持面向对象的,可以通过引用类型描述一类对象所具有的属性和方法. 创建对象实例的方法时是用new 操作符加构造函数:var p=new Person(). 二.Object类型 1.创建Object实例两种方式: 使用new操作符跟Object构造函数. var o = new Object(); o.name = 'dami'; o.age = 25; 使用对象字面量表示法,推荐这种方式,代码量小而且看上去有封装的感觉. var o = { name: 'd

读javascript高级编程08-引用类型之Global、Math、String

一.Global 所有在全局作用域定义的属性和方法,都属于Global对象. 1.URI编码: encodeURI():主要用于对整个URI编码.它不会对本身属于URI的特殊字符进行编码. encodeComponentURI():主要用于对URI中的某一部分进行编码,很常用的是对查询字符串参数进行编码.它会对所有非标准字符进行编码. 对应的解码方法是decodeURI()和decodeURIComponent. var uri='http://www.cnblogs.com?a=1 2&b=陈

读javascript高级编程03-函数表达式、闭包、私有变量

一.函数声明和函数表达式 定义函数有两种方式:函数声明和函数表达式.它们之间一个重要的区别是函数提升. 1.函数声明会进行函数提升,所以函数调用在函数声明之前也不会报错: test(); function test(){ alert(1); } 2.函数表达式不会进行函数提升,函数调用在函数声明之前的话会报错: test(); // test is not a function var test=function(){ alert(1); } 二.递归函数 递归函数是通过在函数内部调用自身实现的

读javascript高级编程09-BOM

一.window 1.在全局作用域中定义的变量和函数会被归在window对象. var a=1,b=2; function add(a,b){ return a+b; } console.log(window.a);//1 console.log(window.add(a,b));//3 有点区别在于,全局变量不能用delete删除,而直接在window对象定义的属性可以用delete删除. 2.计算窗口位置: var leftpos=typeof window.screenLeft=="num

读javascript高级编程12-HTML5脚本编程

一.跨文档消息传递(XDM) 1.发送消息 postMessage(msg,domain)用于发送跨文档消息.第一个参数是要传递的消息内容,第二个参数表示接收方来自哪个域.第二个参数有助于提高安全性,如果发现域不匹配则不会进行操作. 2.接收消息 接收到消息时,会触发window对象的message事件.传递给onmessage事件处理程序的对象主要包含三个信息: data:对应postMessage()第一个参数传入的内容: origin:发送消息的文档所在域.接收到消息后,检测消息来源是非常

读javascript高级编程05-面向对象之创建对象

1.工厂模式 工厂模式是一种常用的创建对象的模式,可以使用以下函数封装创建对象的细节: function CreatePerson(name,age){ var p=new Object(); p.name=name; p.age=age; p.speak=function(){ console.log("my name is "+p.name); } return p; } var p1=CreatePerson('Wang',15); p1.speak(); var p2=Crea

读javascript高级编程14-错误处理与调试

一  错误类型 ECMA规定了常见的7种错误类型: Error: 基类型.其他常见的错误类型都继承自该类型,一般供开发人员抛出自定义错误. EvalError:该类型会在eval()函数使用异常时被抛出.例如:new eval();.实际上在某些版本浏览器下会抛出TypeError,而且本身eval()函数在实际开发中就要谨慎使用,所以抛出EvalError的几率是很小的. RangeError:在数值超出范围时触发.例如:new Array(-1)//RangeError: invalid a