文档对象模型(Document Object Model, DOM)是W3C提出的用于访问和修改文档的接口.

JavaScript设计的初衷是为Web提供交互功能,它通过DOM接口来访问和修改文档.

DOM标准被分为3个部分:

  • 核心 DOM - 针对任何结构化文档的标准模型

  • XML DOM - 针对 XML 文档的标准模型

  • HTML DOM - 针对 HTML 文档的标准模型

DOM节点

在DOM中Html文档是一个文档节点, 在Js中可以使用document对象来访问.

Html文档是以树状结构组织的, 每个标签都是一个节点, 树的根节点为<html>标签.

<!DOCTYPE html>
<html> <head> <meta charset="utf-8">
<title>Hello</title> </head> <body> <p>Hello World!</p> </body> </html>

注意<p>Hello World!</p>其中的文本Hello World!在DOM中被认为是一个文本子节点.

访问节点

DOM标准中提供了3种访问节点的方式:

  • getElementById

  • getElementsByTagName

  • getElementsByClassName

Id可以精确定位元素, TagName和ClassName只能定位一组元素.

DOM中的节点分为Node包括Element, Comment, Documnet等类型, 但是我们主要关心Element.

<!DOCTYPE html>
<html> <body> <p id="p1">Hello World!</p> <script type="text/javascript"> document.getElementById('p1').innerHTML = 'Hello World By Dom!'
// <p id="p1">Hello World By Dom!</p> </script> </body> </html>

innerHTML属性是节点开始标签和结尾标签之间的HTML代码, 修改该属性可以修改节点的子树功能强大.

使用innerHTML属性直接编写HTML源码,需要注意防范XSS攻击.

节点的innerText属性会对字符串进行HTML编码, 保证无法设置HTML标签更为安全.

插入节点

appendChild方法可以将节点插入到节点子树的最后一个:

<!DOCTYPE html>
<html> <body> <div id="d">
<p> Python </p> </div> <script type="text/javascript"> var div = document.getElementById('d');
var js = document.createElement('p')
js.innerText = 'JavaScript'
div.appendChild(js) </script> </body> </html>

若该节点不存在则直接插入, 若存在则进行替换.

insertBefore方法可以在指定节点前插入节点:

<!DOCTYPE html>
<html> <body> <div id="d">
<p id="py"> Python </p> </div> <script type="text/javascript"> var div = document.getElementById('d')
var py = document.getElementById('py');
var js = document.createElement('p')
js.innerText = 'JavaScript'
js.id = 'js'
div.insertBefore(js, py) </script> </body> </html>

删除节点

removeChild可以用于删除节点:

<!DOCTYPE html>
<html> <body> <div id="d">
<p id="py"> Python </p>
<p id="js"> javaScript </p>
</div> <script type="text/javascript"> var div = document.getElementById('d')
var js = document.getElementById('js');
div.removeChild(js) </script> </body> </html>

操作表单

HTML表单的输入控件主要有:

  • 文本框<input type="text"> 用于输入文本;

  • 口令框<input type="password">用于输入口令;

  • 单选框<input type="radio">用于选择一项;

  • 复选框<input type="checkbox">用于选择多项;

  • 下拉框<select>用于选择一项;

  • 隐藏文本<input type="hidden">用户不可见但表单提交时会把隐藏文本发送到服务器;

对于text,password, hidden, select型的输入框只需要通过DOM访问input元素的value属性即可得到输入.

<!DOCTYPE html>
<html> <body> <form>
<label>username: <input id="username" type="text"></label>
<br><br>
<label>password:<input id="password" type="password"></label>
</form> <script type="text/javascript"> var username = document.getElementById('username')
username.value = "finley" </script> </body> </html>

对于redio和checkbox需要检查其checked属性

<!DOCTYPE html>
<html> <body> <form>
<label><input type="radio" id="yes" value="1"> Yes</label>
<label><input type="radio" id="no" value="2"> No</label>
</form> <script type="text/javascript"> var yes = document.getElementById('yes')
var no = document.getElementById('no')
document.write(yes.checked)
document.write("<br>")
document.write(no.checked) </script> </body> </html>

Js还可以通过<form>元素的submit()方法提交表单:

<!DOCTYPE html>
<html> <body> <form id="form1">
<label>username: <input id="username" type="text"></label>
<br><br>
<label>password:<input id="password" type="password"></label>
</form> <script type="text/javascript"> var form = document.getElementById('form1')
form.submit() </script> </body> </html>

DOM事件

用户事件

事件机制允许当特定事件发生时调用函数进行响应:

  • 被点击onclick

  • 表单提交onsubmit

  • 输入内容改变onchanged

  • 界面被加载onload

更多的事件请参见DOM事件 - 菜鸟教程

onclick事件允许对点击事件进行响应:

<!DOCTYPE html>
<html> <body> <button id="btn">Click Me!</button> <script type="text/javascript"> var btn = document.getElementById('btn')
btn.onclick = function() {
btn.innerText = "I am clicked!"
} </script> </body> </html>

onsubmit事件通常用于对输入的校验:

<!DOCTYPE html>
<html> <body> <form id="logup">
<label>username: <input id="username" type="text"></label>
<br><br>
<label>password:<input id="password" type="password"></label>
<br><br>
<label>repeat:<input id="repeat" type="password"></label>
<br><br>
<button id= type="submit">submit</button>
</form> <script type="text/javascript"> var form = document.getElementById('logup')
var password = document.getElementById('password')
var repeat = document.getElementById('repeat')
form.onsubmit = function() {
if (password.value != repeat.value) {
alert('repeat password doesn\'t match')
}
} </script> </body> </html>

时钟事件

setTimeout设定在一段时间间隔之后再执行代码:

<!DOCTYPE html>
<html> <body> <script type="text/javascript"> setTimeout("alert('Time out!')",10 * 1000) </script> </body> </html>

第一个参数为String形式的Js代码, 第二个参数是以毫秒为单位的时间间隔.

setTimeout设定的时钟事件只触发一次后停止.

clearTimeout可以取消时钟事件:

<!DOCTYPE html>
<html> <body> <script type="text/javascript"> var t = setTimeout("alert('Time out!')",10 * 1000)
clearTimeout(t) </script> </body> </html>

setInterval方法与setTimeout方法类似,但是会不停地触发事件而非一次之后停止:

<!DOCTYPE html>
<html> <body> <p id='panel'></p> <script type="text/javascript"> var panel = document.getElementById('panel')
function display() {
panel.innerText = Date()
}
setInterval('display()', 1000)
</script> </body> </html>

clearInterval可以取消时钟事件:

var t = setInterval('display()', 1000)
clearInterval(t)

JavaScript文档对象模型的更多相关文章

  1. JavaScript编程:文档对象模型DOM

    5.文档对象模型DOM JS里的DOM和XML里的DOM不同,但是解析方式是一样的. document.getElementByID("id")根据ID获得元素节点. 创建和操作节 ...

  2. JavaScript中的文档对象模型

    1. DOM基本介绍1 什么是DOMDOM的英语全称为Document Object Model,翻译成中文就 是文档对象模型.也就是说,将整个文档看作是一个对象.而一个文档又是由很多节点组成的, 那 ...

  3. 文档对象模型DOM通俗讲解

    转自:http://www.jb51.net/article/42671.htm 在开始之前先说一点,DOM是非常容易理解的,但是大家说的太官方,让人很是难于理解,我们就用非常简单的语言翻译一遍.加深 ...

  4. 第一百一十三节,JavaScript文档对象,DOM基础

    JavaScript文档对象,DOM基础 学习要点: 1.DOM介绍 2.查找元素 3.DOM节点 4.节点操作 DOM(Document Object Model)即文档对象模型,针对HTML和XM ...

  5. 前端-javascript-DOM(重点)文档对象模型

    1.DOM概念-文档对象模型 // 什么是DOM ? /* Document Object Model 文档对象模型 面向对象: 三个特性 封装 继承 多态 一个对象: 属性和方法 说 万事万物皆对象 ...

  6. 认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。元素、属性和文本的树结构(节点树)。

    认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...

  7. 第一百一十四节,JavaScript文档对象,DOM进阶

    JavaScript文档对象,DOM进阶 学习要点: 1.DOM类型 2.DOM扩展 3.DOM操作内容 DOM自身存在很多类型,在DOM基础课程中大部分都有所接触,比如Element类型:表示的是元 ...

  8. xml.dom——文档对象模型API

    文档对象模型,或者“DOM”,是一个跨语言API的World Wide Web Consortium(W3C)来访问和修改XML文档.DOM的实现提供了一个XML文档树结构,或允许客户机代码从头开始建 ...

  9. 文档对象模型DOM

    文档对象模型 DOM 1 DOM概述 1.1 什么是DOM 文档对象模型 Document Object Model 提供给用户操作document obj 的标准接口 文档对象模型 是表示和操作 H ...

随机推荐

  1. Jersey Client传递中文参数

    客户端需要客户端的包: <dependency> <groupId>com.sun.jersey</groupId> <artifactId>jerse ...

  2. 学习Spring Data JPA

    简介 Spring Data 是spring的一个子项目,在官网上是这样解释的: Spring Data 是为数据访问提供一种熟悉且一致的基于Spring的编程模型,同时仍然保留底层数据存储的特​​殊 ...

  3. [JS] 数据双向绑定原理

    通常在前端开发过程中,经常遇到需要绑定两个甚至多个元素之间的值,比如将input的值绑定到一个h1上,改变input的值,h1的文字也自动更新. <h1 id="title" ...

  4. 【NumberValidators】类库介绍

    NumberValidators是一个用于验证中国大陆证件.号码是否符合国家标准的类库,因为该类库在昨日已经正式发布1.0.0版本至nuget,所以在此介绍下该类库的具体功能. NumberValid ...

  5. leetcode 杨辉三角

    给定一个非负整数 numRows,生成杨辉三角的前 numRows 行. 在杨辉三角中,每个数是它左上方和右上方的数的和. 示例: 输入: 5 输出: [ [1], [1,1], [1,2,1], [ ...

  6. javac编译单文件、多文件引入jar包、-cp解决无法加载主类问题

     引言:很多人用ide集成开发环境用的多了,对dos命令编译多个java文件或引入jar包都变得陌生了,java不同于其他解释语言,如ruby.php 都有require,直接引入即可运行代码,但ja ...

  7. ASP.NET MVC Areas View 引用 外部母版视图

    ASP.NET MVC Area => Areas View 引用 外部母版视图 创建项目:MVCSite.Area 创建mvc area 1.Areas View 引用 外部母版视图 1.1 ...

  8. CentOS 7 - 最小化安装以及引发的问题!

    一,操作系统和虚拟机 操作系统:CentOS 7 官方网站:https://www.centos.org 下载地址:https://www.centos.org/download/ 下载版本分三个:D ...

  9. django url 路由设置技巧

    Django的url使用方法 利用Django开发站点.能够设计出很优美的url规则,假设url的匹配规则(包括正則表達式)组织得比較好,view的结构就会比較清晰.比較easy维护. 最简单的形式 ...

  10. Centos出现-bash: unzip: command not found的解决办法

    利用unzip命令解压缩的时候,出现-bash:  unzip: command not found的错误. unzip——命令没有找到,其原因肯定是没有安装unzip. 利用一句命令就可以解决了.  ...