J**aScript DOM基础

时间:2016.04.18 发布人:b**e82349

J**aScript DOM基础

已解决问题

谷歌b**e82349用户在2016.04.18提交了关于“八达岭长城J**aScript DOM基础”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2024-11-14T12:48:08。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,没有什么华丽的语言,但是我对你的感谢不会减少 !

希望以下的回答,能够帮助你。

第1个回答

用户名:haowang2008  

DOM(DocumentObjectModel)即文档象游氢标跟轮严精明川丰对象模型,针对h**TML和XML文档的API(应用程序接口);

DOM描绘了一个层次化的节点树,运行开发人员可以添加/移除和修改页面的某一部分;

一DOM介绍

D(文档):可以理解为整个Web加载的网页文档;
O(对象):可以理解为类似window对象之类的东西,可以调用属性和方法,这里说的是document对象;
M(模型):可以理解为网页文档的树形结构统们甲落异望限社影;

1.节点

加载h**TML页面时,Web浏览器生成一个树形结构,问答用来表示页面**结构;
DOM将这种节点结构理解为由节点组成;
html元素为根节点;he怎模能ad元素是html的子节点;meta元素和title元素之间是兄弟关系;


2.节点种类:元素节点/文本节点/属性节点
<divtitle="元素属性">测试Div</div>
元素节点=>div;
性节点=>title="元素属性"
文本节点=>测政维笑青传练率准试Div二查找元素
W3C提供了比较方便简单的**破角孩来氢节点的方法和属性,以便我们快速的对节点进行操作;
DOM(DocumentObjectModel)庆即文翟象模型,针对h**TML随将北尼系电次划和XML文档的API(应用程序接口);

DOM描绘了一个层次化的节点树,运行开发人员可以添或角挥为环孔快客接加/移除和修改页面的某一测丰磁劳设判令护立取转部分;

元素节点查找方法
方法说明
getElementById()获到想移经兰虽取特定ID元素的节点;
get称十吗宁印ElementsByTagName()获取相同元素的节点列表;
getElementsByName()获取相同名称的节点列表;
getAttribute()获取特定元素节点属性的值;
setAttribute()设元置特定元素节点属性的值;
removeAttribute()移除特定元素节点属性校半;

1.getElementById()

//方法接收一个参数:获取元素的ID;
//如果侵硫左绝首找到相应的元素则返回该元素的受完陆省那万言刑助h**TMLDivEle径乙溶儿快息纸下庆染印ment对象;如果不存在,则返回**ll;
document.getElementById('box');/热语单并/[objecth**TMLDivElement];
//当我们通过getElementById()获取到特定元素节点时,这个节点对象就被我们获取到了;
//而通过这个节点对象,我们可以访问它的一系列属性;
(1).访问元素节点的属性
属性说明
tagName获取元素节点的标签名;
innerh**TML获取元素节点里的内容,非W3CDOM规范;
document.getElementById('box').tagName;//=>DIV;
document.getElementById('box').innerh**TML;//=>测试Div;

(2).访问h**TML通用属性
属性说明
id元素节点的id名称;
title元素节点的title属性值;
styleCSS内联样式属性值;
classNameCSS元素的类;

document.getElementById('box').id;//=>id;
document.getElementById('box').title;//获取title;

document.getElementById('box').style;//获取CSSStyleDeclaration对象;
document.getElementById('box').style.color;//获取style对象中的color的值;也就是设置在元素行内的样式值;
document.getElementById('box').style.color='red';//设置style对象中的color的值;

document.getElementById('box').className;//获取class;
document.getElementById('box').className='pox';//设置class;

document.getElementById('box').bbb;//获取自定义属性的值,非IE不支持;


2.getElementsByTagName()
//方法返回一个对象数组h**TMLCollection(NodeList)数组,这个数组保存着所有相同元素名的节点列表;
document.getElementsByTagName('*');//利用通配符获取所有元素;
//PS:IE在使用通配符时,会把文档最开始的html的规范声明当作第一个元素节点;

document.getElementsByTagName('li');//=>[objecth**TMLCollection];获取所有li元素;
document.getElementsByTagName('li').[0];//获取第一个li元素;

3.getElementsByName()

获取相同名称(name)设置的元素,返回一个对象数组h**TMLCollection(NodeList);
document.getElementsByName('add');//获取具有name='add'的input元素集合;
//PS:对于并不是h**TML合法的属性,那么在JS获取的兼容性上也会存在差异;
//IE支持合法的name属性,但对于自定义的属性会出现不兼容问题;

4.getAttribute()
方法将获取元素中某个属性值;
但它和直接使用".attr"获取属性值的方法有一定区别;
document.getElementById('box').getAttribute('mydiv');//获取自定义属性值;
document.getElementById('box').mydiv;//获取自定义属性值,仅IE支持;

5.setAttribute()
方法将设置元素中某个属性和值;接收两个参数:属性名和值;
如果属性本身已存在,那么就会覆盖;
document.getElementById('box').setAttribute('align','center');//设置属性和值;
//PS:在IE7及以下,使用setAttribute()方法设置class和style属性没有效果;

6.removeAttribute()
方法可以移除h**TML属性;
document.getElementById('box').removeAttribute('style');//移除style样式属性;

三DOM节点

1.node节点属性

//节点可以分为:元素节点/属性节点和文本节点;
//这些节点都有三个属性:nodeName/nodeType和nodeValue;

信息节点属性
节点类型nodeNamenodeTypenodeValue
元素元素名称1**ll
属性属性名称2属性值
文本#text3文本内容
document.getElementById('box').nodeType;//=>1;元素节点;

2.层次节点属性
//层次节点可以划分为:父节点与子节点/兄弟节点;

//当我们获取其中一个元素节点的时候,就可以使用层次节点属性来获取它相关层次的节点;

节点关系示意图

层次节点属性
属性说明
childNodes读取当前元素节点的所有子节点;
firstChild读取当前元素节点的第一个子节点;
lastChild获取当前元素节点的最后一个子节点;
ownerDocument获取该节点的文档根节点,相当于document;
parentNode获取当前节点的父节点;
previousSibling获取当前节点的前一个同级节点;
nextSibling获取当前节点的后一个同级节点;
attributes获取当前元素节点的所有属性节点集合;

(1).childNodes属性

属性获取某一个元素节点的所有子节点,这些子节点包含元素节点和文本节点;
PS:使用childNodes[n]返回子节点对象的时候,有可能返回的是元素子节点,比如:h**TMLElement;
也可能返回的是文本子节点,比如:Text;
元素子节点可以使用nodeName或者tagName获取标签名称;而文本子节点可以使用nodeValue获取;
varbox=document.getElementById('box');
for(vari=0;i<box.childNodes.length;i++){
判断是元素节点,输出元素标签名;
if(box.childNodes[i].nodeType===1){
console.log('元素节点:'+box.childNodes[i].nodeName);
判断是文本节点,输出文本内容;
}elseif(box.childNodes[i].nodeType===3){
console.log('文本节点:'+box.childNodes[i].nodeValue);
}
}
PS1:在获取到文本节点(重点在于已经不是元素节点)的时候,是无法使用innerh**TML这个属性输出文本内容的;
这个非标准的属性必须在获取元素节点的时候,才能输出里面包含的文本;
alert(box.innerh**TML);innerh**TML和nodeValue第一个区别;

PS2:innerh**TML和nodeValue在赋值的时候,nodeValue会把包含在文本里的h**TML转义成特殊的字符,从而达到形成纯文本的效果;
而innerh**TML会解析文本里的特殊字符;
box.childNodes[0].nodeValue='<strong>abc</strong>';=><strong>abc</strong>;
box.innerh**TML='<strong>abc</strong>';=>abc(样式加粗);

(2).firstChild和lastChild属性
firstChild=childNodes[0];获取当前元素的第一个子节点;
lastChild=childNodes[box.childNodes.length-1];获取当前元素最后一个子节点;

(3).ownerDocument属性
返回该节点的文翟象根节点,返回的对象相当于document;
alert(box.ownerDocument===document);//=>true;根节点;

(4).parentNode/previousSibling/nextSibling属性

parentNode:返回该节点的父节点;
previousSibling:返回该节点的前一个同级节点;
nextSibling:返回该节点的后一个同级节点;
alert(box.parentNode.nodeName);//获取父节点的标签名;
alert(box.firstChild.nextSibling);//获取第二个节点;
alert(box.lastChild.previousSibling);//获取倒数第二个节点;

(5).attributes属性
属性返回该节点的属性节点集合;
alert(document.getElementById('box').attributes);//=>NamedNodeMap;

(6).忽略空白文本节点

varbody=document.getElementsByTagName('body')[0];//获取body元素节点;alert(body.childNodes.length);//非IE=7;IE=3;//PS:在非IE中,标准的DOM具有识别空白文本节点的功能,而IE自动忽略了;functionfilterSpaceNode1(nodes){//新数组;varret=[];for(vari=0;i<nodes.length;i++){//如果识别到空白文本节点,就不添加到数组;if(nodes[i].nodeType===3&&/^\s+$/.test(nodes[i].nodeValue))conti**e;//把每次的元素节点,添加到数组里;ret.push(nodes[i]);}returnret;}//PS:上面的方法,采用忽略空白文件节点的方法,把得到的元素节点累加到数组里返回;functionfilterSpaceNode2(nodes){for(vari=0;i<nodes.length;i++){if(nodes[i].nodeType===3&&/^\s+$/.test(nodes[i].nodeValue)){//得到空白节点之后,一道父节点上,删除子节点;nodes[i].parentNode.removeChild(nodes[i]);}}returnnodes;}//PS:firstChild等方法在获取节点时遇到空白节点,处理方法;functionremoveWhileNode(nodes){for(vari=0;i<nodes.childNodes.length;i++){if(nodes.childNodes[i].nodeType===3&&/^\s+$/.test(nodes.childNodes[i].nodeValue)){nodes.childNodes[i].parentNode.removeChild(nodes.childNodes[i]);}}returnnodes;}

四节点操作
//DOM不单单可以查找节点,也可以创建节点/复制节点/插入节点/删除节点和替换节点

节点操作方法
方法说明
write()这个方法可以把任意字符串插入到文档中;
createElement()创建一个元素节点;
appendChild()将新节点追加到子节点列表的末尾;
createTextNode()创建一个文件节点;
insertBefore()将新节点插入在前面;
replaceChild()将新节点替换旧节点;
cloneNode()复制节点;
removeChild()移除节点;

(1).write()方法
//write()方法可以把任意字符串插入到文档中去;
document.write('<p>这是一个段落!</p>');//解析后文字;

(2).createElement()方法
createElement()方法可以创建一个元素节点;
document.createElement('p');//[objecth**TMLParagraphElement];

(3).appendChild()方法
appendChild()方法将一个新节点添加到某个节点的子节点列表的末尾上;
varbox=document.getElementById('box');
varp=document.createElement('p');//创建一个新元素节点<p>;
box.appendChild(p);//把新元素节点<p>添加子节点末尾;

(4).createTextNode()方法
该方法创建一个文本节点;
vartext=document.createTextNode('段落');
p.appendChild(text);//将文本节点添加到子节点末尾;

(5).insertBefore()方法

//该方法可以把节点添加到指定节点的前面;box.parentNode.insertBefore(p,box);//在<div>之前添加一个<p>;box.insertBefore(newNode,**ll);//将newNode添加到box自列表的最后节点;//PS:insertBefore()方法可以给当前元素的前面创建一个节点,但没有提供给当前元素的后面创建一个节点;functioninsertAfter(newElement,targetElement){//得到父节点;varparent=targetElement.parentNode;//如果最后一个子节点是当前元素,那么直接添加即可;if(parent.lastChild===targetElement){parent.appendChild(newElement);}else{//否则,在当前节点的下一个节点之前添加;达成在当前节点后面添加节点的需求;parentNode.insertBefore(newElement,targetElement.nextSibling);}}

(6).replaceChild()方法
该方法可以把节点替换成指定的节点;
box.parentNode.replaceChild(p,box);//把<div>换成了<p>;

(7).cloneNode()方法

//该方法可以把子节点复制出来;复制后返回的节点副本属于文档所有,但并没有为它指定父节点;
//参数为true:执行深复制,就是复制节点及其整个子节点树;
//参数为false:执行浅复制,只复制节点本身;
varbox=document.getElementById('box');
varclone=box.firstChild.cloneNode(true);//获取第一个子节点,true表示复制内容;
box.appendChild(clone);//添加到子节点列表末尾;

(8).removeChild()方法
该方法删除指定节点;
box.parentNode.removeChild(box);

小结:在下一章~