《Java Script DOM编程艺术》读书笔记——DOM

1、文档:DOM中的“D”

"D"代表document(文档)

2、对象:DOM中的“O”

“O”代表object(对象)
对象的分类

  • 用户定义对象(user-defined object)
  • 内建对象(native object)
  • 宿主对象(host object)

window对象
window对象对应着浏览器窗口本身,这个对象的属性和方法通常统称为BOM(浏览器对象模型)
BOM提供了window.openwindow.blur等方法。以至于被滥用于各种弹出窗口和下拉菜单

3、模型:DOM中的“M”

“M”代表“Model”(模型)
DOM把一份文档表示为一棵树(数学意义上的概念)
示例代码

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title>Shoping List<title>
  </head>
  <body>
     <h1>What to buy</h1>
     <p title="a gentle reminder">Don’t forget to buy this stuff.<p>
     <ul id="purchases">
        <li> A tin of beans<li>
        <li class="sale">Cheese<li>
        <li class="sale important">Milk<li>
        </ul>
    <body>
  </html>
代码中<html>相当于树根,即根元素。<head>和<body>属于下一个分支,位于同一层次且互不包含,属于兄弟关系。<head>元素有两个子元素<meta>和<title>(属于兄弟关系)<body>元素有三个子元素<p>、<h1>、<ul>(这三个属于兄弟关系。<ul>也是一个父元素,有三个子元素,他们都是<li>元素。

如果你能把一个文档的各种元素想象成一棵家谱树,我们就可以用同样的术语描述DOM。但我觉得称为“节点树”更准确

4、节点

节点(node)属于网络术语,它表示网络中的一个连接点。一个网络就是由一些节点构成的集合。DOM也是同样的情况,文档是由节点构成的集合。

  • 元素节点
  • 文本节点
  • 属性节点

4、1元素节点

DOM的原子是元素节点(element node)诸如<body><p><ui>之类的元素。标签的名字就是元素的名字。元素也可以包含其他的元素。没有被包含在其他元素的唯一元素是<html>元素,它是我们的节点树的根元素。

4、2文本节点

在上述例子中,<p>元素包含着文本“don't forget to buy this stuff.”它就是一个文本节点(text node)。

4、3属性节点

属性节点是对元素做出更具体的描述。例如,几乎所有的元素都有一个title属性,我们可以利用这个属性对包含在元素里的东西做出准确的描述:

<p title="a gentle reminder">Don't forget to buy this stuff.<p>

在DOM中title="a gentle reminder"是一个属性节点(attribute node),在前面的例子中无序清单元素<ul>有个id属性。有些清单元素<li>有class属性。

三者之间的关系.png

4、4 CSS

类似javascript脚本,我们也可以将CSS样式嵌在文档<head>部分(style>标签之间)。也可以放在另外的一个文件里。**在HTML文件中引用CSS文件的格式:

<link type="text/css" href="file.css" rel="stylesheet">```
**继承(inheritance)**是CSS技术中的一项强大功能。
1)、 class属性
```html
<p class="special">This pargraph has the special class<p>
<h2 class="special">So dose this headline</h2>```
在样式表里可以为上面的代码进行定义
```css
special{
font-style: italic;
}```
还可以这样定义
```css
h2.special{
text-transform: uppercase;
}```
2)、id属性
id属性的用途是给网页里的某个元素加上一个独一无二的标识符:
```html
<ul id="purchases">```
样式表定义
```css
#purchases{
border:1px solid white;
background-color:#333;
color:#ccc;
padding:1em;
}```
```css
#purchases li{
font-weight:bold;
}```
####4、5获取元素
> 有3种DOM方法可获取元素节点,分别是通过元素ID、通过标签名和通过类名字来获取

- **getElementById**
- **getElementsByTagName**
- **getElementsByClassName**

###1)getElementById
此方法将返回一个与那个有着给定id属性值的元素节点对应的对象,**在javascript里注意大小写**。它是document对象特有的函数,在脚本代码里,函数名的后面必须跟有**一对圆括号**,这对圆括号包含这**函数的参数。**`document.getElementById(id)`在getElementById方法中只有一个参数:**你想获得的那个元素的id属性的值,**这个id属性必须放在单引号或双引号里。`docment.getElementById("purchases")`这个调用将返回一个对象,这个对象对应着document对象里的一个独一无二的元素,那个元素的HTLM id属性值是`purchases`
```html
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title>Shoping List<title>
  </head>
  <body>
     <h1>What to buy</h1>
     <p title="a gentle reminder">Don’t forget to buy this stuff.<p>
     <ul id="purchases">
        <li> A tin of beans<li>
        <li class="sale">Cheese<li>
        <li class="sale important">Milk<li>
        </ul>
     <script>
         alert(typeof docment.getElementById("purchases"));
     </script>
    <body>
  </html>
//利用`typeof`操作符进行验证(typeof操作符可以告诉我们它的操作数是一个字母、数值、函数、布尔值还是对象。

验证可得是一个对象

2)getElementsByTagName

getElementsByTagName方法返回一个对象数组,每个对象分别对应着文档里有着给定标签的一个元素。它的参数是标签的名字:decument.getElementByTagName(tag)

alert(document.getElementsByTagName("li").length);//显示文档里的列表元素个数为:3
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title>Shoping List<title>
  </head>
  <body>
     <h1>What to buy</h1>
     <p title="a gentle reminder">Don’t forget to buy this stuff.<p>
     <ul id="purchases">
        <li> A tin of beans<li>
        <li class="sale">Cheese<li>
        <li class="sale important">Milk<li>
        </ul>
     <script>
         var items=document.getElementByTagName("li");
         for (var i=0; i<items.length;i++){
         alert(typeof items[i]);
         }
     </script>
    <body>
  </html>
//代码运行结果显示三个alert对话框,显示的消息都是“object”。

getElementsByTagName允许把一个通配符作为它的参数,通配符(*)必须放在引号里

alert(document.getElementsByTagName("*").length);//可以知道文档里有多少个元素节点
var shopping=document.getElementById("purchases");
var items=shopping.getElementsByTagName("*");
//程序运行结果,items数组将只包含id属性值是purshase的元素清单的元素

3)getElementByClassName

这个方法让我们能够通过class属性中的类名来访问元素,getElementByClassName也只接受一个参数,就是类名:

getElementByClassName(class)```
这个方法的返回值也与getElementsByTagName类似,都是一个具有相同类名的元素的数组。
```javascript
document.getElementsByClassName("sale")```
利用这种方法还可有查找那些带有多个类名的元素。多个类名之间用空格分开即可
```javascript
alert(document.getElementsByClassName("important sale").length);
//对话框显示1,表示只有一个元素匹配。类名的顺序不重要,就算元素还带有更多类名也没有关系。

也可以和getElementById组合使用

     var shopping=document.getElementById("purchase");
     var sales=shopping.getElementsByClassName("sale");
sales数组中包含的就只是位于“purchases”列表中的带有“sale”类的元素。

getElementByClassName方法非常有用,但只有较新的浏览器才支持它。所以,需要使用已有的DOM方法来实现自己的getElementsByClassName。

function getElementsByClassName(node,classname){
if (node.getElementsByClassName){
//使用现有的方法
return node.getElementsByTagName("*");
for (var i=0; i<elems.length;i++){
  if(elems[i].ClassName.indexof(classname)!= -1){
results[results.length]=elems[i];
          }
      }
return results;
    }
}```
####5 获取和设置属性
- **getAttribute方法**(获取元素的属性)
- **setAttribute方法**(更改属性节点值)

#####5、1getAttribute
getAttribute是一个函数,它只有一个参数(你所要查询的属性的名称)
```html
object.getAttribute(attribute)```
getAttribute只能通过元素节点对象调用。
例如,可以与getElementByTagName方法合用获取每个`<p>`元素的title属性
```html
var paras = document.getElementByTagName("p");
for (var i=0; i<paras.length; i++){
  alert(paras[i].getAttribute("title"));
}
代码运行后显示着文本“a gentle reminder”的alterdui
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容

  • 之前通过深入学习DOM的相关知识,看了慕课网DOM探索之基础详解篇这个视频(在最近看第三遍的时候,准备记录一点东西...
    微醺岁月阅读 4,459评论 2 62
  • 前言 归根结底,代码都是思想和概念的体现。没人能把一种程序设计语言的所有语法和关键字都记住,可以查阅参考书来解决。...
    朱细细阅读 2,920评论 4 14
  • 一、样式篇 第1章 初识jQuery (1)环境搭建 进入官方网站获取最新的版本 http://jquery.co...
    凛0_0阅读 3,358评论 0 44
  • 这几天,都没有更新文章,因为我得病了,身体的不适可以靠药物来治理,那心里的病怎么治? 心里的病就像是一种慢性病毒,...
    haihailo阅读 561评论 0 0
  • 2017年11月23日 星期四 晴 昨天晚上身体有点不舒服没写日记。今天和孩子一块去取订的奶,拿好奶要走...
    圈圈370阅读 140评论 0 0