JavaScript文档对象模型
文档对象模型(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文档对象模型的更多相关文章
- JavaScript编程:文档对象模型DOM
5.文档对象模型DOM JS里的DOM和XML里的DOM不同,但是解析方式是一样的. document.getElementByID("id")根据ID获得元素节点. 创建和操作节 ...
- JavaScript中的文档对象模型
1. DOM基本介绍1 什么是DOMDOM的英语全称为Document Object Model,翻译成中文就 是文档对象模型.也就是说,将整个文档看作是一个对象.而一个文档又是由很多节点组成的, 那 ...
- 文档对象模型DOM通俗讲解
转自:http://www.jb51.net/article/42671.htm 在开始之前先说一点,DOM是非常容易理解的,但是大家说的太官方,让人很是难于理解,我们就用非常简单的语言翻译一遍.加深 ...
- 第一百一十三节,JavaScript文档对象,DOM基础
JavaScript文档对象,DOM基础 学习要点: 1.DOM介绍 2.查找元素 3.DOM节点 4.节点操作 DOM(Document Object Model)即文档对象模型,针对HTML和XM ...
- 前端-javascript-DOM(重点)文档对象模型
1.DOM概念-文档对象模型 // 什么是DOM ? /* Document Object Model 文档对象模型 面向对象: 三个特性 封装 继承 多态 一个对象: 属性和方法 说 万事万物皆对象 ...
- 认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。元素、属性和文本的树结构(节点树)。
认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...
- 第一百一十四节,JavaScript文档对象,DOM进阶
JavaScript文档对象,DOM进阶 学习要点: 1.DOM类型 2.DOM扩展 3.DOM操作内容 DOM自身存在很多类型,在DOM基础课程中大部分都有所接触,比如Element类型:表示的是元 ...
- xml.dom——文档对象模型API
文档对象模型,或者“DOM”,是一个跨语言API的World Wide Web Consortium(W3C)来访问和修改XML文档.DOM的实现提供了一个XML文档树结构,或允许客户机代码从头开始建 ...
- 文档对象模型DOM
文档对象模型 DOM 1 DOM概述 1.1 什么是DOM 文档对象模型 Document Object Model 提供给用户操作document obj 的标准接口 文档对象模型 是表示和操作 H ...
随机推荐
- Spring Boot 应用系列 4 -- Spring Boot 2 整合log4j2
一.背景 1. log4j2传承于log4j和logback,它是目前性能最好的日志处理工具,有关它们的性能对比请看: 2. 除了性能好之外,log4j2有这么几个重要的新features: (1) ...
- 阿里巴巴集团2013实习生招聘技术类笔试卷(B)
一.单选题 1.在常用的网络协议中,___是面向连接的.有重传功能的协议. A.IP B.TCP C.UDP D.DXP 2.500张多米诺骨牌整齐地排成一列,依顺序编号为1.2.3… ...
- C# 中数组、ArrayList、List<T> 区别
一:数组 //定义 ]; //赋值 strs[] = "A"; strs[] = "B"; //修改 strs[] = "C"; //取值 ...
- C# 基础篇
全篇依据 C#高级编程(第9版) 内容记录: 基础知识C# 5.0 基础 分为15章内容来介绍 核心C# 对象和类型 继承 泛型 数组 运算符和类型强制转换 委托和lambda表达式,事件 字符串和正 ...
- Oracle数据库设置Scott登录
Oracle数据库Scott登录 在安装数据库时,用户登录选项中,Scott用户默认是未解锁的. 用户名填写as sysdba:密码是原来设置的,登录进去,新建SQL窗口,输入命令: alert us ...
- onsrcoll和scrollTop兼容与实现
对于onscroll事件的支持 各浏览器 document.document.body.document.documentElement 对象的 onscroll 事件的支持存在差异. 所谓的支持性存 ...
- Spring 开发第一步(四)Spring与JDBC事务
Spring使用各种不同的TransactionManager来管理各种不同数据源事务底层(比如jdbc数据源.hibernate数据源.JPA数据源等等).在此基础上使用各种对应的Template来 ...
- Flask基础-配置,路由
一,配置文件 flask中的配置文件是一个flask.config.Config对象(继承字典),默认配置为: { 'DEBUG': get_debug_flag(default=False), 是否 ...
- 深度优先搜索 - 简单demo
输入一个数n,输出 1 ~ n 的全排列,例如输入 3,全排列则为:123,132,213,231,312,321 一共六种. 这里采用深度优先搜索来解决这个问题: #include<stdio ...
- Zookeeper原理分析之存储结构ZkDatabase
ZKDatabase在内存中维护了zookeeper的sessions, datatree和commit logs集合. 当zookeeper server启动的时候会将txnlogs和snapsho ...