搜索
首页web前端js教程JS中DOM如何操作

JS中DOM如何操作

Mar 19, 2018 pm 05:05 PM
javascript如何操作

DOM即 Document Object Model 是 W3C (万维网联盟)的标准,DOM定义访问 HTML 和 XML 的标准 : W3C文档对象模型(DOM)是中立于平台和语言的接口, 它允许程序 和脚本 动态的访问和更新文档的内容,结构和样式。

W3C Dom 标准被分为 3 个不同的部分: 1.核心DOM -针对任何结构化文档的标准模型 2.XML DOM -针对XML文档的标准模型 3.HTML DOM - 针对HTML文档的标准模型

其中在HTML DOM 中 ,所有事物都是节点 , DOM 是被视为节点数的HTML.1.整个文档是一个文档节点 2.每个HTML元素是元素节点 3.HTML元素内的文本是文本节点 4.每个HTML属性是属性节点 5.注释是注释节点

HTML DOM将HTML文档视作树结构 , 这种结构被称之为节点树, 通过HTML DOM,树中的所有节点均可通过 JavaScript 进行访问 , 所有HTML节点(元素)均可被修改,也可以创建或删除节点.

一些常用的HTML DOM 方法:1.getElementById(id)-获取带有指定id的节点(元素) 2.appendChid(node)-插入新的子节点(元素) 3.removeChild(node)-删除子节点(元素)

一些常用的HTML DOM属性: 1.innerHTML-节点(元素)的文本值 2.parentNode-节点(元素)的父节点 3.childNodes-节点(元素)的子节点 4..attributes-节点(元素)的属性节点

DOM操作

创建元素

var newp = document.createElement("p");设置类名 newp.className = "item";设置ID

newp.id = "first";设置背景色 newp.style.background = "red";添加 元素box 进body中

先获取要添加的元素

var body = document.getElementsByTagName("body")[0];var box = document.getElementsByClassName("box")[0];body.appendChild(newp);//body中现有两个内容 , 一个是newp 一个是box//现在的情况是把newp的内容插到box后面

要想把p中的内容插入到box的前面 则如下: body.insertBefore(newp , box);删除元素 body.removeChild(box);//删除box标签 box.remove();DOM属性

节点 : 标签 文本 注释 声明(doctype)

可以通过如下方法获取元素下单所有节点: console.log(box.childNodes); 获取标签类型的子节点 , 得到的节点是一个标签 console.log(box.cheildren[0]);尺寸 位置 console.log(newp.offsetWidth);//打印宽度 包含边框 console.log(newp.clientWidth);//不含边框也不含滚动条(可视区域) console.log(newp.scrollHeight);//也是元素垂直 / 水平滚动了的距离, 或者是元素卷帘卷走的视觉看不到的部分overflow 处理超出部分 visible默认可见overflow:scroll; //出现滚动条位置 相对于定位父级的一个位置 console.log(newp.offsetTop); console.log(newp.offsetLeft);子元素滚动上去的一段距离, 除了scrollTop外,以上元素都是只读 console.log(newp.scrollTop)

定时器

一次性定时器 , 只能使用一次

写法1: var time = setTimeout(function(){ console.log("一次性定时器"); },1000);写法2: function f1(){ console.log("一次性定时器"); } setTimeout(f1,1000);清除一次性定时器 clearTimeout(time);循环计时器, 每隔一段时间,就会执行一次函数

写法1: var timer = setInterval(funtion(){ console.log("循环计时器"); })var timer = setInterval(f2 , 1000);清除循环定时器 clearInterval(timer);DOM是HTML文档结构 其实就是为了能JS操作html元素而制定的一个规范, dom的根本就是document对象,该对象有很多属性和放法 例如 创建节点 复制节点 移除节点 修改属性等 DOM对象的出现是为了方便javascript 操作HTML标签而已 , DOM全面为Document Object Model (文档对象模型), 也是基于HTML 文档出来的 , 提供给Javascript用来动态(比如点击事件)修改文档的状态, 所以操作DOM就是在操作HTML文档对象(每一个标签)

CSS就是将HTML文档样式而已,而javascript能把HTML和CSS相结合 , 也就是以前所说的DHTML(动态HTML)

DOM就是将XML (或者HTML)内的节点定义成基本统一的对象数据可以提供程序语言 (如 javascript) 控制的技术规范

可以使用javascript语言来操作DOM以改变网页,为了改变网页,你必须告诉Javascript操作哪一个节点,这就是操作DOM

操作DOM可以让你更改网页的交互方式.所有网页的交互都依赖这种DOM技术,即使不用Javascript,也可以使用其他语言来操作DOM

DOM是一棵树,数值和树叶都做了编号 , 你告诉一个脚本 一个函数去寻找那一个枝干的哪一个叶子,对这个这个叶子要做什么改变

当你在知乎的搜索栏输入数据时,Javascript 捕获到了你的输入 ,对服务器使用异步查询 , 动态显示搜索结果.

当你向下滑动时 , Javascript 捕获到了你滑动的距离,根据距离的大小来判断是否改变, DOM, 进而让顶部的导航栏跟随浏览器窗口滚动,免得你回头去找.

当你点击修改按钮时, javascript , 捕获到了这个按钮的鼠标点击事件,反馈了一个可编辑的答案给你

Javascript 不能够真正改变DOM 他仅仅是改变呈现的内容,当你刷新的时候就会发现呈现的内容消失了.

但是你可以把这些改变用请求的方式传递给后端语言接口 , 由后端语言 PHP Python Java Node 等 来进行后续的操作 , 他们接到你的请求之后就去修改服务器数据,这样改变就生效了刷新后不会消失 了

但是用户的交互 比如弹窗 滑过变色等等根本没必要让服务器也跟着搀和 原因是 交互只是暂时的 用完了还要变成默认的 不需要保存到服务器 只要保证交互的时候有反馈就可以了.

HTML 表达静态结构 (网页的基本元素 每个元素的基本功能 元素的基本功能可以产生什么意义,这个意义能产生什么样的内容)

CSS 呈现层次美化 (元素的基本及特殊属性 元素的形状,状态,元素的布局)

Javascript 负责动态交互(操作 DOM使用 AJAX 进行异步刷新 , 与服务器交互) 该链接介绍的还不算错. https://www.zhihu.com/question/34219998/answer/58211568DOM是Javascript操作网页的接口 , 全称叫 文档对象模型 (Document Object Model) 他的作用是将网页转化为一个javascript对象, 从而用Javascript脚本进行各种操作(比如增删元素等)

浏览器会根据DOM模型, 将结构文档化 (比如 HTML 或者 XML等 ) 解析成一系列的节点, 再由这些节点解析成树状结构(Dom Tree), 所有的节点和最终的树状结构都有规范的对外接口 , 所以DOM可以理解成网页的编程接口. DOM有标准的国际标准, 我们目前使用的是DOM3

严格的来说 DOM 不属于 Javascript 但是DOM操作是Javascript最常见的任务 而Javascript 最常见的任务 最常见的DOM操作语言.

DOM

DOM即 Document Object Model 是 W3C (万维网联盟)的标准

DOM定义访问 HTML 和 XML 的标准 : W3C文档对象模型(DOM)是中立于平台和语言的接口, 它允许程序 和脚本 动态的访问和更新文档的内容,结构和样式

W3C Dom 标准被分为 3 个不同的部分: 1.核心DOM -针对任何结构化文档的标准模型 2.XML DOM -针对XML文档的标准模型 3.HTML DOM - 针对HTML文档的标准模型

其中在HTML DOM 中 ,所有事物都是节点 , DOM 是被视为节点数的HTML.1.整个文档是一个文档节点 2.每个HTML元素是元素节点 3.HTML元素内的文本是文本节点 4.每个HTML属性是属性节点 5.注释是注释节点

HTML DOM将HTML文档视作树结构 , 这种结构被称之为节点树, 通过HTML DOM,树中的所有节点均可通过 JavaScript 进行访问 , 所有HTML节点(元素)均可被修改,也可以创建或删除节点.

一些常用的HTML DOM 方法:1.getElementById(id)-获取带有指定id的节点(元素) 2.appendChid(node)-插入新的子节点(元素) 3.removeChild(node)-删除子节点(元素)

一些常用的HTML DOM属性: 1.innerHTML-节点(元素)的文本值 2.parentNode-节点(元素)的父节点 3.childNodes-节点(元素)的子节点 4..attributes-节点(元素)的属性节点

DOM操作

创建元素

var newp = document.createElement("p");设置类名 newp.className = "item";设置ID

newp.id = "first";设置背景色 newp.style.background = "red";添加 元素box 进body中

先获取要添加的元素

var body = document.getElementsByTagName("body")[0];var box = document.getElementsByClassName("box")[0];body.appendChild(newp);//body中现有两个内容 , 一个是newp 一个是box//现在的情况是把newp的内容插到box后面

要想把p中的内容插入到box的前面 则如下: body.insertBefore(newp , box);删除元素 body.removeChild(box);//删除box标签 box.remove();DOM属性

节点 : 标签 文本 注释 声明(doctype)

可以通过如下方法获取元素下单所有节点: console.log(box.childNodes); 获取标签类型的子节点 , 得到的节点是一个标签 console.log(box.cheildren[0]);尺寸 位置 console.log(newp.offsetWidth);//打印宽度 包含边框 console.log(newp.clientWidth);//不含边框也不含滚动条(可视区域) console.log(newp.scrollHeight);//也是元素垂直 / 水平滚动了的距离, 或者是元素卷帘卷走的视觉看不到的部分overflow 处理超出部分 visible默认可见overflow:scroll; //出现滚动条位置 相对于定位父级的一个位置 console.log(newp.offsetTop); console.log(newp.offsetLeft);子元素滚动上去的一段距离, 除了scrollTop外,以上元素都是只读 console.log(newp.scrollTop)

定时器

一次性定时器 , 只能使用一次

写法1: var time = setTimeout(function(){ console.log("一次性定时器"); },1000);写法2: function f1(){ console.log("一次性定时器"); } setTimeout(f1,1000);清除一次性定时器 clearTimeout(time);循环计时器, 每隔一段时间,就会执行一次函数

写法1: var timer = setInterval(funtion(){ console.log("循环计时器"); })var timer = setInterval(f2 , 1000);清除循环定时器 clearInterval(timer);DOM是HTML文档结构 其实就是为了能JS操作html元素而制定的一个规范, dom的根本就是document对象,该对象有很多属性和放法 例如 创建节点 复制节点 移除节点 修改属性等 DOM对象的出现是为了方便javascript 操作HTML标签而已 , DOM全面为Document Object Model (文档对象模型), 也是基于HTML 文档出来的 , 提供给Javascript用来动态(比如点击事件)修改文档的状态, 所以操作DOM就是在操作HTML文档对象(每一个标签)

CSS就是将HTML文档样式而已,而javascript能把HTML和CSS相结合 , 也就是以前所说的DHTML(动态HTML)

DOM就是将XML (或者HTML)内的节点定义成基本统一的对象数据可以提供程序语言 (如 javascript) 控制的技术规范

可以使用javascript语言来操作DOM以改变网页,为了改变网页,你必须告诉Javascript操作哪一个节点,这就是操作DOM

操作DOM可以让你更改网页的交互方式.所有网页的交互都依赖这种DOM技术,即使不用Javascript,也可以使用其他语言来操作DOM

DOM是一棵树,数值和树叶都做了编号 , 你告诉一个脚本 一个函数去寻找那一个枝干的哪一个叶子,对这个这个叶子要做什么改变

当你在知乎的搜索栏输入数据时,Javascript 捕获到了你的输入 ,对服务器使用异步查询 , 动态显示搜索结果.

当你向下滑动时 , Javascript 捕获到了你滑动的距离,根据距离的大小来判断是否改变, DOM, 进而让顶部的导航栏跟随浏览器窗口滚动,免得你回头去找.

当你点击修改按钮时, javascript , 捕获到了这个按钮的鼠标点击事件,反馈了一个可编辑的答案给你

Javascript 不能够真正改变DOM 他仅仅是改变呈现的内容,当你刷新的时候就会发现呈现的内容消失了.

但是你可以把这些改变用请求的方式传递给后端语言接口 , 由后端语言 PHP Python Java Node 等 来进行后续的操作 , 他们接到你的请求之后就去修改服务器数据,这样改变就生效了刷新后不会消失 了

但是用户的交互 比如弹窗 滑过变色等等根本没必要让服务器也跟着搀和 原因是 交互只是暂时的 用完了还要变成默认的 不需要保存到服务器 只要保证交互的时候有反馈就可以了.

HTML 表达静态结构 (网页的基本元素 每个元素的基本功能 元素的基本功能可以产生什么意义,这个意义能产生什么样的内容)

CSS 呈现层次美化 (元素的基本及特殊属性 元素的形状,状态,元素的布局)

Javascript 负责动态交互(操作 DOM使用 AJAX 进行异步刷新 , 与服务器交互) 该链接介绍的还不算错. https://www.zhihu.com/question/34219998/answer/58211568DOM是Javascript操作网页的接口 , 全称叫 文档对象模型 (Document Object Model) 他的作用是将网页转化为一个javascript对象, 从而用Javascript脚本进行各种操作(比如增删元素等)

浏览器会根据DOM模型, 将结构文档化 (比如 HTML 或者 XML等 ) 解析成一系列的节点, 再由这些节点解析成树状结构(Dom Tree), 所有的节点和最终的树状结构都有规范的对外接口 , 所以DOM可以理解成网页的编程接口. DOM有标准的国际标准, 我们目前使用的是DOM3

严格的来说 DOM 不属于 Javascript 但是DOM操作是Javascript最常见的任务 而Javascript 最常见的任务 最常见的DOM操作语言.

相关推荐:

js中DOM知识点分享

以上是JS中DOM如何操作的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
node.js流带打字稿node.js流带打字稿Apr 30, 2025 am 08:22 AM

Node.js擅长于高效I/O,这在很大程度上要归功于流。 流媒体汇总处理数据,避免内存过载 - 大型文件,网络任务和实时应用程序的理想。将流与打字稿的类型安全结合起来创建POWE

Python vs. JavaScript:性能和效率注意事项Python vs. JavaScript:性能和效率注意事项Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差异主要体现在:1)Python作为解释型语言,运行速度较慢,但开发效率高,适合快速原型开发;2)JavaScript在浏览器中受限于单线程,但在Node.js中可利用多线程和异步I/O提升性能,两者在实际项目中各有优势。

JavaScript的起源:探索其实施语言JavaScript的起源:探索其实施语言Apr 29, 2025 am 12:51 AM

JavaScript起源于1995年,由布兰登·艾克创造,实现语言为C语言。1.C语言为JavaScript提供了高性能和系统级编程能力。2.JavaScript的内存管理和性能优化依赖于C语言。3.C语言的跨平台特性帮助JavaScript在不同操作系统上高效运行。

幕后:什么语言能力JavaScript?幕后:什么语言能力JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript在浏览器和Node.js环境中运行,依赖JavaScript引擎解析和执行代码。1)解析阶段生成抽象语法树(AST);2)编译阶段将AST转换为字节码或机器码;3)执行阶段执行编译后的代码。

Python和JavaScript的未来:趋势和预测Python和JavaScript的未来:趋势和预测Apr 27, 2025 am 12:21 AM

Python和JavaScript的未来趋势包括:1.Python将巩固在科学计算和AI领域的地位,2.JavaScript将推动Web技术发展,3.跨平台开发将成为热门,4.性能优化将是重点。两者都将继续在各自领域扩展应用场景,并在性能上有更多突破。

Python vs. JavaScript:开发环境和工具Python vs. JavaScript:开发环境和工具Apr 26, 2025 am 12:09 AM

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。

JavaScript是用C编写的吗?检查证据JavaScript是用C编写的吗?检查证据Apr 25, 2025 am 12:15 AM

是的,JavaScript的引擎核心是用C语言编写的。1)C语言提供了高效性能和底层控制,适合JavaScript引擎的开发。2)以V8引擎为例,其核心用C 编写,结合了C的效率和面向对象特性。3)JavaScript引擎的工作原理包括解析、编译和执行,C语言在这些过程中发挥关键作用。

JavaScript的角色:使网络交互和动态JavaScript的角色:使网络交互和动态Apr 24, 2025 am 12:12 AM

JavaScript是现代网站的核心,因为它增强了网页的交互性和动态性。1)它允许在不刷新页面的情况下改变内容,2)通过DOMAPI操作网页,3)支持复杂的交互效果如动画和拖放,4)优化性能和最佳实践提高用户体验。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器