1.查询文档的一个或多个元素有如下方法

a. 用指定的id属性;(若一个文档中有两个相同的id,只会选择第一个;在低于IE8的IE中,getElementById()对匹配元素的ID不区分大小写,而且也会返回匹配name属性的元素;)

b.基于name属性选取HTML元素;(getElementsByName()定义在HTMLDocument类中,只在HTML文档可用,在XML文档中不可能)

c.通过标签名来查询

d.通过快捷属性来访问各种各样的节点;(document.imgs/ document.forms/ document.links/ document.iframes/ document.anchors/ document.body/ document.head/ document.documentElement/ document.scripts[html5]

e.通过css类来选取元素(一个空格隔开的class属性列表)

f.通过css选择器来选取元素;

注意: 以上几种方法返回的NodeList或HTMLCollection对象都是实时的,如果在后续操作中动态添加或删除一些元素后,它们会实时的进行更新

但在querySelector/querySelectorAll方法中返回的NodeList对象,是静态的,不会实时去更新

=====================================================================

1.children  与 childNodes

  childNodes  标准属性,IE9以下会除去文本,属性,只会获取html节点,IE9及chrome ff会获取文本,属性节点

  children  只会获取html节点

2.firstChild,lastChild 与firstElementChild,lastElementChild

  firstElementChild与lastElementChild 是标准属性,只会获取html节点,但IE9以下不支持

  firstChild与lastChild 在IE9以下只会获取HTML节点,其余的会获取文本,属性,及html节点,可以通过nodeType去判断

节点演示

3.nodeType(节点常量)

Element 元素节点 1
Attr 属性节点 2
Text 文本节点 3
CDATASection CDATASection节点 4
Comment 注释节点 8
Document Document文档节点 9
DocumentFragment Document片段 11

4.nodeName(节点名称, 大写)

Element 标签名
Attr 属性名称
Text #text
Document #document

5.nodeValue(节点值)

Element null
Attr 属性值
Text 文本值
Document null

6.引自javascript权威指南第六版有用的几个函数

a. 返回元素e的第n层祖先元素,如果不存在此类祖先或祖先不是Element(Document,DocumentFragment)则返回null

返回祖先元素function parent(e, n) {
if ( n === undefined) n = 1;
while ( n -- && e) e = e.parentNode;
if (!e || e.nodeType !== 1) return null;
return e;
}

b.返回元素e的第n个兄弟元素,(n为正,则是后续的第n个兄弟元素,n为负,则是前面的第n个兄弟元素,n为零,返回e本身)

返回兄弟元素function sibling(e, n) {
while (e && n !== 0){
if (n > 0) {
if (e.nextElementSibling) e = e.nextElmentSibing;
else{ //兼容Ie8以下的
for(e = e.nextSibling; e && e.nodeType !== 1; e = e.nextSibling) //空循环
}
n--;
}
else{
if (e.previousElementSibling) e = e.previousElmentSibing;
else{ //兼容Ie8以下的
for(e = e.previousSibling; e && e.nodeType !== 1; e = e.previousSibling) //空循环
}
n++;
}
}
return e;
}

c.返回元素e的第n个子元素,如果不存在则为null;(n为负,代表从后向前计数,0表示第一个子元素,而-1代表最后一个;-2代表倒数第二个)

返回子元素function child (e, n) {
if(e.child){
if(n < 0) n += e.children.length //转换负的n为数组索引
if( n < 0 ) return null
return e.children[n]
}
if(n >= 0){ //n非负: 从第一个子元素向前数
if (e.firstElementChild) e = e.firstElementChild;
else{
for(e = e.firstChild; e && e.nodeType !== 1; e = e.nextSibling)
}
return sibling(e, n);
}
else{
if (e.lastElmentChild) e = e.lastElementChild;
else{ //n为负:从最后一个子元素往回数
for( e = e.lastChild; e && e.nodeType !== 1; e = e.previousSiblings)
}
return siblings(e, n+1); //+1来转化最后1个子元素为最后1个兄弟元素
}
}

=====================================================================

属性

HTMLElement定义了通用的一些属性

a.核心属性(class,id,style,title)

b.语言属性(dir,lang,xml:lang)

c.键盘属性(accessKey,tabindex)

d.事件程序属性

e. 特定的Element子类型为其子元素定义了特定的属性

注意: 表示HTML属性的值通常是字符串,当属性为布尔值或数值时,属性也是布尔值或数值,而不是字符串,事件程序属性值总是Function对象(或null)

HTML属性名不区分大小写,但JavaScript属性名对大小写敏感,若属性名包含不止一个单词,则将除了第一个单词以外的单词的首字母大写(defaultChecked/tabIndex)

有些HTML属性名在JavaScript中是保留字,对于这些属性,一般的规则是为属性名加前缀“html”(如htmlFor);但也有例外(className)

以上都是针对标准html属性;如果要获取和设置非标准的HTML属性,则用以下方法

getAttribute()  //获取    ie < 8 中  for  ==> htmlFor    class ==> className

setAttribute()  //设置    ie < 8 中  for  ==> htmlFor    class ==> className

hasAttribute()  //检测属性是否存在   ie < 8中没有此方法

removeAttribute()   //完全删除属性

注意:这四个方法和上述的区别

属性值都被看来字符串

方法使用标准属性名,甚至当这些名称为JavaScript保留字也不例外(setAttribute(‘class’,'fsy’))

如果操作包含来自其他命名空间中属性的XML文档,可以使用以下4个命名空间版本

getAttributeNS()/setAttributeNS()/hasAttributeNS()/removeAttributeNS()

这些方法需要两个属性名字符串作为参数,而不是一个,第一个是标识命名空间的URI,第二个通常是属性的本地名字,在命名空间中是无效的。但setAttributeNS()的第二个参数是属性的有效名字,它包含命名空间的前缀

用法:w3c  XML DOM - Element 对象

在IE7及IE6中有一些属性无法通过getAttribute/setAttribute来来进行操作,需要用getAttributeNode/setAttributeNode来进行,

1.getAttributeNode  是先得到属性节点,然后取得属性值
       2. getAttributeNode 效率低一点
        3.可以解决IE6 7下一些不能取值的Bug

IE6-7  Attribute

==================================================================

03/09/2013补记

<a href ="../index.html id="link">link</a>

document.getElementById('link').href  ==> '域名’ + index.html

document.getElementById('link').getAttribute('href') ==> '../index.html'

DOM之节点|属性的更多相关文章

  1. [js高手之路] dom常用节点属性兼容性详解与应用

    一.每个DOM节点都有一个nodeType属性,表示节点类型, NodeType一共有12种类型,我们可以通过遍历内置的Node构造函数获取 window.onload = function(){ v ...

  2. DOM常用的属性和方法

    之前一直傻傻分不清DOM和JavaScript究竟有什么区别,随着相关工作时间的增长,开始逐渐区分DOM和JavaScript了,最近,也一直在复习有关DOM方面的知识,<JavaScript ...

  3. DOM节点属性

    节点属性 在文档对象模型 (DOM) 中,每个节点都是一个对象.DOM 节点有三个重要的属性 : 1. nodeName : 节点的名称 2. nodeValue :节点的值 3. nodeType ...

  4. 节点属性(DOM对象)

    节点属性 在文档对象模型 (DOM) 中,每个节点都是一个对象.DOM 节点有三个重要的属性 : 1. nodeName : 节点的名称 2. nodeValue :节点的值 3. nodeType ...

  5. Javascript进阶篇——(DOM—节点---属性、访问节点)—笔记整理

    节点属性在文档对象模型 (DOM) 中,每个节点都是一个对象.DOM 节点有三个重要的属性 : 1. nodeName : 节点的名称 2. nodeValue :节点的值 3. nodeType : ...

  6. DOM 节点属性

    DOM 节点属性 在文档对象模型 (DOM) 中,每个节点都是一个对象.DOM 节点有三个重要的属性 : 1. nodeName : 节点的名称 2. nodeValue :节点的值 3. nodeT ...

  7. 使用DOM解析XML文件,、读取xml文件、保存xml、增加节点、修改节点属性、删除节点

    使用的xml文件 <?xml version="1.0" encoding="GB2312" ?> <PhoneInfo> <Br ...

  8. 节点操作,节点属性的操作及DOM event事件

    ##1. 节点操作 createElement(标签名) 创建一个指定名称的元素 someone.appendChild(new_node) 追加一个子节点(作为最后的子节点) someone.ins ...

  9. 简述HTML DOM及其节点分类

    在JavaScript中,document这个对象大家一定很熟悉,哪怕是刚刚开始学习的新人,也会很快接触到这个对象.而document对象不仅仅是一个普通的JavaScript内置对象,它还是一个巨大 ...

随机推荐

  1. 总结JavaScript输出内容(document.write)

    document.write() 可用于直接向 HTML 输出流写内容.简单的说就是直接在网页中输出内容. 第一种:输出内容用“”括起,直接输出""号内的内容.<script ...

  2. jquery1.9学习笔记 之选择器(基本元素三)

    标签选择器("element") 描述: 选择所有与给出标签名相匹配的元素. 同功能的JS原生方法:getElementByTagName() 例子:  查找每个div元素. &l ...

  3. Python新手学习基础之数据类型——变量

    关于Python的变量是这样描述的: 变量是存储在内存里的一个值,通过变量名,我们可以访问到该变量的值. 上面这几行代码中,price,count和sum都是变量,Python是动态类型语言,变量是不 ...

  4. Caffe : Layer Catalogue(1)

    原文:http://caffe.berkeleyvision.org/tutorial/layers.html 参考:http://blog.csdn.net/u011762313/article/d ...

  5. js运算符的优先级

    自上向下优先级降低 运算符 描述 . [] () 字段访问.数组下标.函数调用以及表达式分组 ++ -- - ~ ! delete new typeof void 一元运算符.返回数据类型.对象创建. ...

  6. 利用GPS获取行车速度和距离

    这几天项目中需要GPS计算汽车的速度和行驶距离,这里简单记录一下使用过程 1 和平常使用地图一样,在Info.plist中添加位置请求 2 在viewdidLoad中初始化locationManage ...

  7. CCI_chapter 3 Stacks and Queues

    3.1Describe how you could use a single array to implement three stacks for stack 1, we will use [0, ...

  8. Unity中的关节

    关节组件一共分为5大类,它们分别是链条关节.固定关节.弹簧关节.角色关节和可配置关节.链条关节(Hinge Joint):将两个物体以链条的形式绑在一起,当力量过大超过链条的固定力矩时,两个物体就会产 ...

  9. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  10. Linux企业级项目实践之网络爬虫(15)——区分文本文件和二进制文件

    HTTP协议支持文本和二进制文件传输.最常见的html格式的页面即文本,图片.音乐等为二进制文件.我们要对这两类文件加以区分并分别处理. static char * BIN_SUFFIXES = &q ...