文档对象模型DOM通俗讲解

时间:2024-05-13 09:36:55 

在开始之前先说一点,DOM是非常容易理解的,但是大家说的太官方,让人很是难于理解,我们就用非常简单的语言翻译一遍。加深对DOM的理解,从而对它有一个全面的认识。

什么是DOM

DOM的全称是Document Object Model,即文档对象模型,它允许脚本控制Web页面、窗口和文档。

如果没有DOM,JavaScript将是另外一种脚本语言;而有了DOM,它将成为制作动态页面的强有力工具。DOM不是JavaScript语言的一部分,而是内置在浏览器中的一个应用程序接口。当然,我们可以简单的理解为一种用于HTML和XML文档的编程接口。它给文档提供了一种结构化的表示方法,可以改变文档的内容和呈现方式。

DOM(文档对象模型)是一组用来描述脚本怎样与结构化文档进行交互和访问的web标准。他的功能是把浏览器支持的文档(包括HTML XML XHTML)当作一个对象来解析。DOM实际上是一个操作文档里面所包含的内容的一个编程的API,允许开发人员从文档中读取、搜索、修改、增加和删除数据。DOM是与平台和语言无关的,也就是说只要是支持DOM的平台和编程语言,你都可以用来编写文档。

DOM定义了一系列对象、方法和属性,用于访问、操作和创建文档中的内容、结构、样式以及行为。每一个网页元素(一个HTML标签)都对应着一个对象(object,所谓“对象”,用白话说就是“东西”。)。网页上的标签是一层层嵌套的,最外面的一层是<HTML>,文档对象模型也这样一层层嵌套着,但是通常被理解成一棵树的形状。树根是window或document对象,相当于最外层的标签的外围,也就是整个文档。树根之下(这棵树的图通常是倒着画,就好像遗传谱系或者家谱那样。树根就是唯一的共同祖先)是子一级的对象,子对象也有它自己的子对象,除了根对象以外,所有的对象都有自己的父对象,同一对象的子对象之间就是兄弟的关系。如果大家没有见过家谱,应该知道一个公司的组织架构。
文档对象模型DOM通俗讲解 
DOM实际上是以面向对象方式描述的文档模型。DOM定义了表示和修改文档所需的对象、这些对象的行为和属性以及这些对象之间的关系。可以把DOM认为是页面上数据和结构的一个树形表示,不过页面当然可能并不是以这种树的方式具体实现。通过JavaScript,可以重构整个 HTML 文档。可以添加、移除、改变或重排页面上的项目。

要改变页面的某个东西,JavaScript 就需要获得对 HTML 文档中所有元素进行访问的入口。这个入口连同对 HTML 元素进行添加、移动、改变或移除的方法和属性,都是通过文档对象模型来获得的(DOM)。

DOM和JavaScript

我们用JavaScript对网页进行的所有操作都是通过DOM进行的。如何访问DOM中的对象?

先是父对象名,后面接着是子对象名,使用圆点隔开。


<span style="font-size:18px">window.document.write("hi!how are you!")</span>


DOM操作Checkbox实例


<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>DOM操作checkbox</title>
<script type="text/javascript">
//当html页面加载完后;执行以下函数
window.onload = function() {
document.getElementById("btn").onclick = function() {
var inputs = document.getElementsByTagName("input");
for ( var i = 0; i < inputs.length; i++) {
if (inputs[i].type = "checkbox") {
if (inputs[i].value % 2 != 0) {
inputs[i].checked = true;
}
}
}
}
}
</script>
</head>
<body>
<input type="checkbox" value="1" />
<input type="checkbox" value="2" />
<input type="checkbox" value="3" />
<input type="checkbox" value="4" />
<input type="checkbox" value="5" />
<input type="checkbox" value="6" />
<input type="checkbox" value="7" />
<input type="checkbox" value="8" />
<input type="checkbox" value="9" />
<input type="checkbox" value="10" />
<button id="btn">选中奇数</button>
</body>
</html>


单机按钮显示效果:
文档对象模型DOM通俗讲解 

标签:文档对象模型,DOM
0
投稿

猜你喜欢

  • Go语言操作MySQL的知识总结

    2024-01-26 01:43:17
  • 详解用python实现基本的学生管理系统(文件存储版)(python3)

    2021-10-08 18:26:29
  • 浅谈为什么#{}可以防止SQL注入

    2024-01-27 07:19:08
  • IE6 iframe 横向滚动条问题

    2009-01-18 13:31:00
  • Python同步遍历多个列表的示例

    2023-08-08 00:20:10
  • sql2008 还原数据库解决方案

    2024-01-26 07:16:59
  • httpwatch 的页面元素加载时间表

    2008-02-13 08:28:00
  • python实现简单登陆流程的方法

    2021-01-30 00:48:24
  • 详解从vue的组件传值着手观察者模式

    2024-05-10 14:19:01
  • 一个ASP(VBScript)简单SQL语句构建“类”

    2008-03-12 07:08:00
  • Oracle 常用的SQL语句

    2009-08-02 07:09:00
  • ASP网站数据采集经验谈

    2008-03-09 15:30:00
  • Python生成九宫格图片的示例代码

    2023-03-16 20:29:38
  • 对python过滤器和lambda函数的用法详解

    2022-04-23 06:37:47
  • Python与AI分析时间序列数据

    2022-02-25 09:36:07
  • 基于vue打包后字体和图片资源失效问题的解决方法

    2024-05-05 09:12:13
  • Python pygame绘制文字制作滚动文字过程解析

    2022-06-10 13:21:11
  • 一文搞懂Go语言标准库strconv

    2024-04-23 09:41:45
  • TMDPHP 模板引擎使用教程

    2023-11-15 03:21:56
  • JavaScript"模拟事件"的注意要点详解

    2024-04-30 09:56:47
  • asp之家 网络编程 m.aspxhome.com