DOM

什么是DOM?简单地说DOM是一套对文档内容进行抽象和概念化的方法。

  W3C给出的DOM定义是这样的:“一个与系统平台和编程语言无关的接口,程序和脚本以通过这个接口动态的访问和修改文档的内容,结构和样式。”

  那么楼主在这里主要是跟大家分享下JavaScript中如何使用DOM,当然如果会用JavaScript使用DOM,当你使用PHP或是Python之类的语言来解析XML文档的时候,我们获得的DOM新知识将会有很大的帮助。

DOM中的“D",”O",“M”。

  “D”当然就是“document”了,没有document的存在DOM也就无从谈起,浏览器在加载完我们所写的网页时,DOM就在后台产生了。浏览器将之转化为一个可读的文档对象。

  "O"呢,就是“object”,JavaScript中对象分为三种,分别是:用户自定义对象(用户自行创建的对象),宿主对象(浏览器提供的对象)和内建对象(JavaScript中的内建对象,如:Math,Date)。对象就是我们操作的主要目标。

  “M"怎么说呢,说它是”Modle"可以,也能说是“Map”本身DOM的存在就是让我们对整个文档有一个把握,所以说它是模型有道理,说它是地图也有道理。这里我们姑且把它当做是Map吧,既然是地图,那必然要有诸如图例,方向,等高线和比例尺之类的图例。我们要向看懂地图就需要对这些图例了如指掌。对于DOM同样如此,DOM把文档表示成一棵树(这里的“树”是数学上的概念),也是我们理解和运用这一模型的关键。家谱树模型非常适合用来表示一分用(X)HTML编写的文档。

比如:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Canvas</title>
<style>
</style>
</head>
<body>
<h1 title="example">Examples</h1>
<p>A example</p>
<ul id="number">
<li class="one">第一条</li>
<li class="two">第二条</li>
<li class="three">第三条</li>
</ul>
</body>
</html>

节点

    节点是个网络术语,他表示的是构成网络中的一个连接点。一个网络就是由一些节点所构成的集合。

那么在DOM中同样存在节点,浏览器所解析的文档就是由一个个的节点构成,这个节点就是我们上面所画出来的树中的树叶和树枝。那么这些树叶和树枝被分为了三种:元素节点,属性节点,文本节点。,接下来我们一一看一下:

1.元素节点

元素节点其实很好理解,我们文档中诸如body,p,ul,li等标签都是一个元素节点。

标签的名字就是元素节点的名字。

比如:

<p>A example</p>

这里的p标签就是一个元素节点,p就是元素节点的名称。

2.属性节点

属性节点是为了对元素做出更具体的描述,比如我们文档中:

<h1 title="example">Examples</h1>

这里的title就是一个属性节点,属性节点用用比较广泛,CSS中的诸如style,id,class我们都可以把它看做是一个属性节点访问。

3.文本节点

文本节点就更容易理解了,就是文本内容嘛。比如:

<ul>
<li>第一条</li>
<li>第二条</li>
<li>第三条</li>
</ul>

在XHTML中文本节点被包含在元素节点的内部,当并非所有的元素节点都包含文本节点,就像这里的ul标签没有文本内容,它包含了li标签,li有文本内容,里面的内容就构成了文本节点。

获取元素

有三种方法可以获取元素节点,分别是通过元素ID(getElementByID),通过标签名字(getElementByTagName),通过类名字(getELementByClassName)来获取:

1.getElementById

注意:JavaScript区分大小写,getELementById这几个字母不能写错了

<script>
var number=document.getElementById("number");
alert(typeof number);
</script>

我们会得到 如图所示的alert对话框:



由此我们也能更深入的理解了HTML中处处皆对象的概念。

2.getElementByTagName

getElementTagName会得到一个数组,这个数组对应着给定标签的每一个元素,

比如:

var element=document.getElementsByTagName("li");
for(var i=0;i<element.length;i++){
alert(typeof element[i]);
}

我们依然可以看到:



3.getElementByClassName

var element=document.getElementsByClassName("one");
alert(typeof element);

我们仍旧可以看到:



到这里我们就学完了获取元素的三种方法,我想你一定厌倦了看那么多变的显示着object的alert对话框,你一定也明白了文档中每个节点都是一个对象。

那么我们下一次就要说一下节点对象的属性和方法了。利用这些方法我们就可以随心所欲的改变文档中的内容,甚至改变某些元素的属性。

下面是对本次学习的一个总结:

一份文档就是一棵节点树.

节点分为不同的类型,元素节点,属性节点和文本节点等。

getElementByTagName和getElementByClassName将返回一个对象数组,他们对应着一组特定的元素节点。

每个节点都是一个对象。

Happy hacking !

JavaScript DOM学习总结(一)的更多相关文章

  1. javascript DOM 学习总结 (1)

    摘自javascript DOM编程艺术 1.首先介绍DOM的三个字母的含义: 1.1  D 如果没有document(文档),DOM 也无从谈起,当创建了一个网页并把他加载到web浏览器中时,DOM ...

  2. JavaScript DOM学习总结(二)

    获取和设置属性 DOM实在是个好东西,掌握了它我们不仅可以在JavaScript中使用,其它程序语言我们同样可以使用. 接下来就一起使用DOM来干些实事吧! 1.getAttribute getAtt ...

  3. 《JavaScript DOM 编程艺术》 学习笔记

    目录 <JavaScript DOM 编程艺术> 学习笔记 第一章 js简史 第二章 js语法 准备工作 语法 第三章 DOM DOM中的D DOM中的O DOM中的M 第四章 js图片库 ...

  4. JavaScript DOM编程艺术学习笔记(一)

    嗯,经过了一周的时间,今天终于将<JavaScript DOM编程艺术(第2版)>这本书看完了,感觉受益匪浅,我和作者及出版社等等都不认识,无意为他们做广告,不过本书确实值得一看,也值得推 ...

  5. 初步总结javascript中学习DOM之前的知识

    嘿嘿,又到了周末时间,周六其实就是总结这周的学习的,记得周二周三刚开始接触javascript时间,还是不知道怎么学习的,就感觉找不到方向,那时间学习的只是总结了一些简单的定义或者是学习结构,今天就把 ...

  6. javascript DOM 操作

    在javascript中,经常会需要操作DOM操作,在此记录一下学习到DOM操作的知识. 一.JavaScript DOM 操作 1.1.DOM概念 DOM :Document Object Mode ...

  7. JavaScript DOM 编程艺术(第2版)读书笔记(1)

    JavaScript 简史 JavaScript 是Netscape公司与Sun公司合作开发的.在 JavaScript 1.0发布时,Netscape Navigator主宰着浏览器市场.微软在推出 ...

  8. JavaScript DOM动态创建(声明)Object元素

    http://www.cnblogs.com/GuominQiu/archive/2011/04/01/2002783.html 一文提及“等整个页面加载完毕后,根据用户所选的阅读机类型,再用Java ...

  9. JavaScript DOM编程艺术第一章:JavaScript简史

    本系列的博客是由本人在阅读<JavaScript DOM编程艺术>一书过程中做的总结.前面的偏理论部分都是书中原话,觉得有必要记录下来,方便自己翻阅,也希望能为读到本博客的人提供一些帮助, ...

随机推荐

  1. 如何做到在虚拟数据库和真实数据库之间自由切换?【低调赠送:QQ高仿版GG 4.4 最新源码】

    记得以前在公司上班时,有时候白天的活没干完,我就会把工作带回家晚上加班继续做.但是,我们开发用的数据库是部署在公司局网内部的一台服务器上的,在家里是肯定连不上这台机器的.在家里没有数据库,服务端就跑不 ...

  2. 人人都是 DBA(XV)锁信息收集脚本汇编

    什么?有个 SQL 执行了 8 秒! 哪里出了问题?臣妾不知道啊,得找 DBA 啊. DBA 人呢?离职了!!擦!!! 程序员在无处寻求帮助时,就得想办法自救,努力让自己变成 "伪 DBA& ...

  3. dijit样式定制(三)Button、RadioButton、CheckBox

    dijit.form.DropDownButton dijit的button中除了ComboButton使用table布局外,其他的button都是用span嵌套布局,下图中可看一下button的主要 ...

  4. buildbot入门系列—介绍篇

    一.介绍 1. buildbot是一个开源的基于python的持续集成系统,它能够以下三种方式触发相应的自动构建和测试运行,从而迅速的发现问题所在,同时指出造成这个错误的开发人员,当然我们还可以通过页 ...

  5. Java中测试异常的多种方式

    使用JUnit来测试Java代码中的异常有很多种方式,你知道几种? 给定这样一个class. Person.java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...

  6. java 锁2

    并发,其实是多线程才有的场景... java 多线程? 锁? 现在看来,即使已经工作了4.5年,这仍然不是一个简单的问题. 其实java 本身有提供锁的机制. 比如 Object对象的 wait .n ...

  7. Ubuntu & MacOS安装Mysql & connector

    Ubuntu & MacOS安装Mysql & connector 1. 安装MySql sudo apt-get install mysql-server apt-get insta ...

  8. Redis学习笔记~分布式的Pub/Sub模式

    回到目录 redis的客户端有很多,这次用它的pub/sub发布与订阅我选择了StackExchange.Redis,发布与订阅大家应该很清楚了,首先一个订阅者,订阅一个服务,服务执行一些处理程序(可 ...

  9. Thrift架构~thrift中间语言的认识(只有它什么都不是,它才有可能什么都是)

    中间语言是我为thrift语言起的名字,呵呵,为什么叫它中间语言呢,其实意思很简单,就是说,它只是一个过程,而不是一个最终的结果,而结果需要这个中间过程的影响,没有中间语言,结果语言也不能产生,在th ...

  10. MVVM架构~knockoutjs系列之验证成功提示显示

    返回目录 对于knockout.validation来说,我们已经知道了如何去验证大部分表单元素,而有时,我们的需求希望在每个元素验证成功后,去显示正确的提示,这个我们很容易的使用self.元素.is ...