前言

这一章节介绍 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. 快速阅读《QT5.9 c++开发指南》2

    1.sample2_2 信号和槽 MFC中最让人印象深刻的就是"消息映射",这里有理由相信,"信号和槽"是这种功能的发扬和扩展.通过简单的 connect(ui ...

  2. 20145308 《网络对抗》 MAL_后门应用与实践 学习总结

    20145308 <网络对抗> MAL_后门应用与实践 学习总结 实践目的 使用nc实现win和Linux间的后门连接 meterpreter的应用 MSF POST的应用 知识点学习总结 ...

  3. java常用类-String类

    * 字符串:就是由多个字符组成的一串数据.也可以看成是一个字符数组. * 通过查看API,我们可以知道 * A:字符串字面值"abc"也可以看成是一个字符串对象. * B:字符串是 ...

  4. Python 数据分析 - 索引和选择数据

    loc,iloc,ix三者间的区别和联系 loc .loc is primarily label based, but may also be used with a boolean array. 就 ...

  5. C语言变量的作用域和存储类型

    1.动态局部变量:也称局部变量.自动变量,是指在函数内部定义的自动变量,不带static修饰,作用域是定义该变量的子程序.在退出函数后,变量自带内存会自动释放. 2.静态局部变量:是指在函数内部定义的 ...

  6. 深度学习课程笔记(四)Gradient Descent 梯度下降算法

    深度学习课程笔记(四)Gradient Descent 梯度下降算法 2017.10.06 材料来自:http://speech.ee.ntu.edu.tw/~tlkagk/courses_MLDS1 ...

  7. ffmpeg 下载安装和简单应用

    一.ffmpeg下载 先到http://ffmpeg.org/下载ffmpeg安装文件 二.ffmpeg安装 1.解压下载完的ffmpeg-20190319-f8075b2-win64-shared. ...

  8. Luncene学习二《搜索索引》

    搜索索引的流程 第一步:创建一个Directory对象,也就是索引库存放的位置 第二步:创建一个IndexReader对象,需要指定Directory对象 第三步:创建一个indexsearcher对 ...

  9. Vue学习四:v-if及v-show指令使用方法

    本文为博主原创,未经允许不得转载: <!DOCTYPE html> <html lang="zh"> <head> <meta http- ...

  10. windows 上让文件类型和程序关联的批处理程序。

    文件关联工具 地址: https://github.com/wll8/assoc-tool 本工具可以用来为你的便携程序添加文件关联,比如 nodepad2.exe . vscode 或其他图片处理程 ...