JavaScript和HTML DOM的区别与联系及Javascript和DOM的关系


Posted in Javascript onNovember 15, 2015

区别:

javascript

JavaScript 是因特网上最流行的浏览器脚本语言。很容易使用!你一定会喜欢它的!

JavaScript 被数百万计的网页用来改进设计、验证表单、检测浏览器、创建cookies,以及更多的应用。

HTML DOM

HTML DOM 是 W3C 标准(是 HTML 文档对象模型的英文缩写,Document Object Model for HTML)。

HTML DOM 定义了用于 HTML 的一系列标准的对象,以及访问和处理 HTML 文档的标准方法。

通过 DOM,可以访问所有的 HTML 元素,连同它们所包含的文本和属性。可以对其中的内容进行修改和删除,同时也可以创建新的元素。

HTML DOM 独立于平台和编程语言。它可被任何编程语言诸如 Java、JavaScript 和 VBScript 使用。

联系:

通过 JavaScript,您可以重构整个 HTML 文档。您可以添加、移除、改变或重排页面上的项目。

要改变页面的某个东西,JavaScript 就需要获得对 HTML 文档中所有元素进行访问的入口。这个入口,连同对 HTML 元素进行添加、移动、改变或移除的方法和属性,都是通过文档对象模型来获得的(DOM)。
Javascript主要是利用HTML DOM去获得、改变、创建HTML元素,从而达到美化页面、操作页面元素的目标。因此,在Javascript中最常见的就是各种各样的HTML DOM元素以及它们各自的属性。除了这些DOM元素外,Javascript有自己的对象,例如数组。

简单说,可以认为Javascript主要是操纵HTML DOM。两者是不一样的。
Javascript是语言,DOM是可以在各种语言中(不仅js,php也有的)动态修改文档的模型。

下面单独拉出JavaScript与DOM的关系给大家详解

JavaScript与浏览器的工作

1.浏览器获取并加载你的页面,从上至下解析它的内容。

 遇到JavaScript时,浏览器会解析代码,检查它的正确性,然后执行代码。

 浏览器还会建立一个HTML页面的内部模型(DOM)。

2.JavaScript继续执行,使用DOM检查页面、完成修改、从页面接受事件,或者要求浏览器从Web服务器获取其它数据。

JavaScript如何与页面交互?

JavaScript是代码,HTML是标记,完全不同的东西

怎么让它们交互呢?

答案是使用文档对象模型(Docunment Object Model,简称DOM)。

DOM的妙处在于:它能够在所有浏览器上提供一种一致的方式,通过代码访问HTML的结构和内容。

1、在浏览器加载一个页面时,浏览器会解析HTML,并创建文档的一个内部模型,其中包含HTML标记的所有元素。

2、JavaScript可以与DOM交互(JavaScript使用DOM创建或删除元素等等)

document是一个反映HTML的对象,通过调用document的方法改变DOM的状态,也就是改变HTML页面

3、JavaScript修改了DOM时,浏览器会随着动态更新页面。

自制DOM

材料:格式正确的HTML5页面,WEB浏览器

做法:

 1、在最上面创建一个document节点

 2、取HTML页面的最顶层元素,在这里就是<HTML>元素,把它作为document的子节点加到DOM中

 3、对于当前元素中嵌套的每一个元素,将该元素作为当前元素的子节点增加到DOM

 4、对于刚增加的元素,执行第三步,重复工作,直到处理完所有元素

HTML页面如下  

<!DOCTYPE html>
 <html lang="helloworld">
 <head>
 <title>DOM</title>
 <meta cherset="utf-">
 <script src="dom.js" ></script>
 </head>
 <body>
 <h>My Dom</h>
 <div id="entry">
  <h>hello</h>
  <p>
  Today, I am making a dom!!!
  </p>
 </div>
 </body>
 </html>

得到的DOM如下图

JavaScript和HTML DOM的区别与联系及Javascript和DOM的关系

Javascript 相关文章推荐
JavaScript和CSS通过expression实现Table居中显示
Jun 28 Javascript
js树插件zTree获取所有选中节点数据的方法
Jan 28 Javascript
详解基于Bootstrap扁平化的后台框架Ace
Nov 27 Javascript
详解页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题
Dec 03 Javascript
详解JavaScript中localStorage使用要点
Jan 13 Javascript
node.js 动态执行脚本
Jun 02 Javascript
canvas仿iwatch时钟效果
Mar 06 Javascript
微信小程序“摇一摇”的实例代码
Jul 20 Javascript
BootStrap Table实现server分页序号连续显示功能(当前页从上一页的结束序号开始)
Sep 12 Javascript
Vue之mixin全局的用法详解
Aug 22 Javascript
vue中前进刷新、后退缓存用户浏览数据和浏览位置的实例讲解
Sep 21 Javascript
vue2.0基于vue-cli+element-ui制作树形treeTable
Apr 30 Javascript
WEB前端开发都应知道的jquery小技巧及jquery三个简写
Nov 15 #Javascript
JS使用eval解析JSON的注意事项分析
Nov 14 #Javascript
js读取并解析JSON类型数据的方法
Nov 14 #Javascript
基于JS实现PHP的sprintf函数实例
Nov 14 #Javascript
javascript动态生成树形菜单的方法
Nov 14 #Javascript
node.js回调函数之阻塞调用与非阻塞调用
Nov 13 #Javascript
JavaScript在网页中画圆的函数arc使用方法
Nov 13 #Javascript
You might like
PHP HTML代码串截取代码
2008/12/29 PHP
Can't create/write to file 'C:\WINDOWS\TEMP\...MYSQL报错解决方法
2011/06/30 PHP
PHP daddslashes 使用方法介绍
2012/10/26 PHP
浅谈使用 PHP 进行手机 APP 开发(API 接口开发)
2014/08/11 PHP
浅谈javascript的调试
2015/01/28 Javascript
JavaScript获取文本框内选中文本的方法
2015/02/20 Javascript
jquery实现加载进度条提示效果
2015/11/23 Javascript
JavaScript编写简单的计算器
2015/11/25 Javascript
移动手机APP手指滑动切换图片特效附源码下载
2015/11/30 Javascript
详解javascript中原始数据类型Null和Undefined
2015/12/17 Javascript
js根据手机客户端浏览器类型,判断跳转官网/手机网站多个实例代码
2016/04/30 Javascript
AngularJs页面筛选标签小功能
2016/08/01 Javascript
Vuex简单入门
2017/04/19 Javascript
JavaScript实现移动端页面按手机屏幕分辨率自动缩放的最强代码
2017/08/18 Javascript
利用jqprint插件打印页面内容的实现方法
2018/01/09 Javascript
关于Vue项目跨平台运行问题的解决方法
2018/09/18 Javascript
详解React 服务端渲染方案完美的解决方案
2018/12/14 Javascript
layui2.0使用table+laypage实现真分页
2019/07/27 Javascript
nodejs中使用archive压缩文件的实现代码
2019/11/26 NodeJs
javascript数组元素删除方法delete和splice解析
2019/12/09 Javascript
Angular 多模块项目构建过程
2020/02/13 Javascript
python实现提取百度搜索结果的方法
2015/05/19 Python
Python调用SQLPlus来操作和解析Oracle数据库的方法
2016/04/09 Python
python多线程调用exit无法退出的解决方法
2019/02/18 Python
Pyqt清空某一个QTreeewidgetItem下的所有分支方法
2019/06/17 Python
PyQT5 QTableView显示绑定数据的实例详解
2019/06/25 Python
pytorch快速搭建神经网络_Sequential操作
2020/06/17 Python
一篇文章带你搞定Ubuntu中打开Pycharm总是卡顿崩溃
2020/11/02 Python
Python使用windows设置定时执行脚本
2020/11/12 Python
新年团拜会主持词
2014/04/02 职场文书
建议书格式
2015/02/04 职场文书
升职自我推荐信范文
2015/03/25 职场文书
python 利用PyAutoGUI快速构建自动化操作脚本
2021/05/31 Python
windows11怎么查看自己安装的版本号? win11版本号的查看方法
2021/11/21 数码科技
Spring IOC容器Bean的作用域及生命周期实例
2022/05/30 Java/Android
Win10此设备不支持接收Miracast无法投影的解决方法
2022/07/07 数码科技