前言

这一章节介绍 DOM, 
使用 DOM 的目的是使的网页能够变得 dynamic,使得 pages that react, that respond, that update themselves after they've been loaded.

什么是 DOM ?

结构:


以 document 开始,接下来是 这个element,接下来是 和 这两个 element,不断内嵌深入。

定义:

When you load a page into the browser, ont only does the browser parse the HTML and then render it to the display, it also creates a set of objects that represent your mark up. These objects are stored in DOM.

简而言之, DOM 是 a set of objects to represent mark-ups

DOM 是 HTML 与 JavaScipt 的共同之处

JavaScript and HTML are two different things. HTML is markup and JavaScript is code.但是它们有一个共同之处,那就是DOM. 通过它,两者可以进行相互的交流

使用 DOM

步骤

  1. LABLE: 在 HTML 中 lable 一个 element 的 id:<p id:greenplanet></p>
  2. CREATE:在 JavaScript 中创建一个 element object,需要使用到document 这个 global object 和它的 getElementById: var planet = document.getElementById("greenplanet")
  3. MODIFY:使用刚刚创建的 object 的方法:innerHTML, 来修改其内容:
  4. MODIFYL:还可以用 document object 的 getAttibute 和 setAttribute 两种方法来设置 element object 的属性,格式为:setAttribute("nameOfAttribute","valueOfAttribute")

其他知识:

  • CREATE 相关: document 这个 object 属于 built-in object, 并且它含有很多附带的 attribute 和 method,可以调用。
  • CREATE 相关:除了 getElementById() 这种方法来确定有 id 属性的 element,还可以使用 getElementbyClassName() 来确定有 class 属性的 element.
  • MODIFY 相关:innerHTML 指的是不包括两边 tags 的 HTML,此外还有 outerHTML 是包括 tags 的 HTML.
  • MODIFY相关:不仅仅可以 get element from the DOM,还可以 Create and add elements to the DOM, Remove elements from the DOM, Traverse the elements in the DOM.

解决 geyElementById 返回值为 null 的问题

问题原因

由于代码从上往下运行,在调用document.getElement() 的时候,并没有显示处所要的 id ,所以返回值为 null.

解决办法

格式:

使用 window 这个 bullt-in object 的一个叫做 onload的 property,它的作用是 get called after the page has loaded.
其中 window 这个 object 本质上 represent the broswer window.

范例:

<script>
function init() {
var planet = document.getElementById("greemplanet");
planet.innerHTML = "Red Alert: hit by phaser fire!";
} window.onload = init;
</script>

关于 onload 这个 property

格式:为 onload assign 一个函数
范例:window.onload = init;
(注意不要加括号,因为不是使用函数值,而是调用函数)
详细内容:
onload,属于 callback,或者 event handler
,它先给一个 object 一个 function ,然后当object 执行到某一个时刻之时,再进行调用这个 function.
作者是这样写的:

A callback works like this: give a function to the object that knows about the event. When the event occurs, that object will call you back, or notify you, by calling that function

onload 这个时刻代表了 as soon as the page is fully loaded.

并且这里还有其他的 event 用于 JavaScript 中的 event handler 来处理

JavaScript 第六章总结: Getting to know the DOM的更多相关文章

  1. javascript第六章--BOM

    ① window对象 ② location对象 ③ navigator对象 ④ screen对象 ⑤ history对象

  2. 第六章 组件 67 使用ref获取DOM元素和组件引用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  3. 读《编写可维护的JavaScript》第六章总结

    第六章 避免使用全局变量 JavaScript执行环境在很多方面都有其独特之处,全局变量就是其中之一.“全局变量”是一个神秘的对象,它表示了脚本的最外层上下文. 在浏览器中,windows对象往往重载 ...

  4. 为什么我要放弃javaScript数据结构与算法(第六章)—— 集合

    前面已经学习了数组(列表).栈.队列和链表等顺序数据结构.这一章,我们要学习集合,这是一种不允许值重复的顺序数据结构. 本章可以学习到,如何添加和移除值,如何搜索值是否存在,也可以学习如何进行并集.交 ...

  5. 《Javascript高级程序设计》阅读记录(六):第六章 下

    这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 <Javascript ...

  6. [书籍翻译] 《JavaScript并发编程》第六章 实用的并发

    本文是我翻译<JavaScript Concurrency>书籍的第六章 实用的并发,该书主要以Promises.Generator.Web workers等技术来讲解JavaScript ...

  7. JavaScript DOM编程艺术-学习笔记(第五章、第六章)

    第五章: 1.题外话:首先大声疾呼,"js无罪",有罪的是滥用js的那些人.js的father 布兰登-艾克,当初为了应付工作,10天就赶出了这个js,事后还说人家js是c语言和s ...

  8. JavaScript高级程序设计:第六章

    第六章 面向对象的程序设计 一.理解对象 1.属性类型: ECMAScript中有两种属性:数据属性和访问器属性. (1)数据属性: 数据属性包含一个数据值的位置.在这个位置可以读取和写入值.数据属性 ...

  9. KnockoutJS 3.X API 第六章 组件(5) 高级应用组件加载器

    无论何时使用组件绑定或自定义元素注入组件,Knockout都将使用一个或多个组件装载器获取该组件的模板和视图模型. 组件加载器的任务是异步提供任何给定组件名称的模板/视图模型对. 本节目录 默认组件加 ...

随机推荐

  1. linux tmux 工具使用 tmux.conf 文件

    set -g prefix ^a unbind ^b bind a send-prefix unbind '"' bind - splitw -v unbind % bind \ split ...

  2. topcoder srm 510 div1

    problem1 link 令$f(x)$表示[0,x]中答案的个数.那么题目的答案为$f(b)-f(a-1)$ 对于$f(x)$来说,假设$x$有$d$位数字,即$[0,d-1]$,那么可以进行动态 ...

  3. Eclipse搭建maven project web war项目pom.xml报错

    在eclipse中搭建maven project时,在不使用模板的情况下,搭建的web项目会报错. 操作步骤如下: 1.勾选Create a simple project ,因为如果不勾选系统会提供模 ...

  4. Python3 tkinter基础 Listbox delete 删除单个、所有元素

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  5. sudo中的 各类授权 名称包含的操作 权限命令?

    sudo是 do something as super user: 或者说: as Super User Do something: 就是 为 "非根用户赋予根用户的权限" 使用 ...

  6. hdu5628 Clarke and math

    题目地址 题目链接 题意 求 \[ g(i)=\sum_{i1|i}\sum_{i_2|i_1}\sum_{i_3|i_2}...\sum_{i_k|i_{k-1}}f(i_k)\space mod\ ...

  7. C++笔记(2018/2/7)

    类class 类的名字就是用户自定义的类型的名字.可以像使用基本类型那样来使用它. 一个类所占用的内存空间的大小,等于所有成员变量的大小之和. 类之间可以用 "="进行赋值,但是不 ...

  8. Win10下Java开发环境配置

    首先下载符合操作系统版本的jdk,比如64位的JDK8: 下载链接:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-down ...

  9. Netty 核心组件笔记

    Netty是一款高效的NIO框架和工具,基于JAVA NIO提供的API实现. 在JAVA NIO方面Selector给Reactor模式提供了基础,Netty结合Selector和Reactor模式 ...

  10. redis事务之watch

    三.redis事务之watch 首先要了解redis事务中watch的作用,watch命令可以监控一个或多个键,一旦其中有一个键被修改(或删除),之后的事务就不会执行.监控一直持续到exec命令(事务 ...