【浏览器】聊聊DOM

博客说明

文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!

说明

作为前端开发,在以前的工作中大多是和DOM打交道,到了现在,大多数前端工程师都是和Vue打交道了。让Vue去和DOM交流。这并非是讽刺,只是说明这个事实,同时也说明了Vue的强大。

但,想要更深的了解前端,需要打开Vue的保护伞,看看DOM,更甚的是,熟悉DOM。走向底层,同时也走向高层!

没准下一代“Vue”的开发者不姓尤。

什么是DOM?

首先来介绍一下,什么是DOM,这个臭了的问题,还是在这里得以继续延伸,我很抱歉,但是还是不能去掉这个过程。

听听W3C的

DOM全程是文档对象模型(Document Object Model),是一项 W3C (World Wide Web Consortium) 标准。它主要定义了访问文档的标准:

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

W3C DOM 标准被分为 3 个不同的部分:

  • Core DOM - 所有文档类型的标准模型

    • Document:文档对象

    • Element:元素对象

    • Attribute:属性对象

    • Text:文本对象

    • Comment:注释对象

    • Node:节点对象,其他5个的父对象

  • XML DOM - XML 文档的标准模型
  • HTML DOM - HTML 文档的标准模型
听听总结的

DOM就是将标记语言文档的各个组成部分,封装为对象。然后开发者(前端切图仔)就可以使用这些对象,对标记语言文档进行CRUD的动态操作。

什么是HTML DOM?

当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。注意,通过 HTML DOM,JavaScript 能够访问和改变 HTML 文档的所有元素。

HTML DOM 是 HTML 的标准对象模型和编程接口。它定义了:

  • 作为对象的 HTML 元素
  • 所有 HTML 元素的属性
  • 访问所有 HTML 元素的方法
  • 所有 HTML 元素的事件

换言之:HTML DOM 是关于如何获取、更改、添加或删除 HTML 元素的标准

总结

咱们熟悉的总结又来了️,这次不多说,HTML DOM就是一套对HTML元素的CURDCURD在看各位没有不熟悉,没有不兴奋的吧。

Document:文档对象

Document对象的属性和方法:HTML DOM Document 对象

创建(获取)

在html dom模型中可以使用window对象来获取,例如在浏览器中输入document,就会返回一个文档对象。

window.document
document

Element对象

Element 对象可以拥有类型为元素节点、文本节点、注释节点的子节点。

获取Element对象的方法

getElementById():根据id属性值获取元素对象。id属性值一般唯一

getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组

getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组

getElementsByName():根据name属性值获取元素对象们。返回值是一个数组

Element属性和方法

乍一看实在是太多了,多得我那是根本不想数,但是又不想直接CV在此。

属性 / 方法 描述
element.accessKey 设置或返回元素的快捷键。
element.appendChild() 向元素添加新的子节点,作为最后一个子节点。
element.attributes 返回元素属性的 NamedNodeMap。
element.childNodes 返回元素子节点的 NodeList。
element.className 设置或返回元素的 class 属性。

给个开头,再把完全的地址贴出来,HTML DOM Element 对象

Attr对象

在 HTML DOM 中,Attr 对象表示 HTML 属性,HTML 属性始终属于 HTML 元素。

操作方法

removeAttribute():删除属性

setAttribute():设置属性

Attr的属性和方法

HTML DOM Attr 对象

DOM 4 警告!

在 W3C DOM Core 中,Attr (attribute) 对象从 Node 对象继承所有属性和方法。

在 DOM 4 中,Attr 对象不再从 Node 继承。为了保证未来的代码安全,应该避免在属性对象上使用节点对象的属性和方法。

NamedNodeMap 对象

在 HTML DOM 中,NamedNodeMap 对象表示元素属性节点的无序集合,NamedNodeMap 中的节点可通过名称或索引(数字)来访问。

Text对象

Text 对象代表 HTML 表单中的文本输入域,该元素可创建一个单行的文本输入字段。当用户编辑显示的文本并随后把输入焦点转移到其他元素的时候,会触发 onchange 事件句柄。

Text的属性和方法

HTML DOM Input Text 对象

Comment对象

Comment是注释对象,在对HTML编码时,总会有一些注释,但是注释的代码,众所周知,是没有被执行的。在HTML中,它就存放在Comment对象中。

createComment() 方法可创建注释节点,一般对这个对象的操作比较的少,也没啥地址可贴的了。

最后说的话

在写这篇文章的时候,我一直在思考有没有必要写这样的一篇文章,其实感觉写这样的文章很难,尽管大多数是一些标准和协议,但往往就是这些标准和协议难以突破,同时自己也在慢慢积累与沉淀,能沉下心写,甚至抄点基础的东西,补足那个圆的一节,感觉会很踏实很多。

本文也是第二次扩写,从500到1500。有机会,或者再有累计的话再扩写吧,到时希望在这些标准之上有所突破哈。

感谢

万能的网络

菜鸟教程w3school

以及勤劳的自己,个人博客GitHub测试GitHub

公众号-归子莫,小程序-小归博客

【浏览器】聊聊DOM的更多相关文章

  1. Javascript 强制浏览器渲染Dom文档

    在Cordova+Framework7开发Hybrid App时,在iPhone 7上遇到一个诡异的现象(Chrome浏览器.Android都正常):js修改手风琴中的input文本框的值后,但页面仍 ...

  2. Chrome浏览器控制台[DOM] Password field is not contained in a form:

    [DOM] Password field is not contained in a form: ( [DOM]密码字段不包含在form表单中) 解决方案:添加一层form标签 <div cla ...

  3. 浏览器兼容——DOM事件封装函数

    //封装函数var eventUtil={    //添加事件    addHandler:function(element,type,handler){        if(element.addE ...

  4. DOM对象本身也是一个js对象,所以严格来说,并不是操作这个对象慢,而是说操作了这个对象后,会触发一些浏览器行为(转)

    一直都听说DOM很慢,要尽量少的去操作DOM,于是就想进一步去探究下为什么大家都会这样说,在网上学习了一些资料,这边整理出来. 首先,DOM对象本身也是一个js对象,所以严格来说,并不是操作这个对象慢 ...

  5. 转---JS 一定要放在 Body 的最底部么?聊聊浏览器的渲染机制

    作者:德来 segmentfault.com/a/1190000004292479 如有好文章投稿,请点击 → 这里了解详情 一.从一个面试题说起 面试前端的时候我喜欢问一些看上去是常识的问题.比如: ...

  6. DOM,浏览器,javascript,html之间的关系

    来源于:https://github.com/hucheng91/myBlog/blob/master/web/dom/dom.md DOM定义 DOM可以以一种独立于平台和语言的方式访问和修改一个文 ...

  7. 浏览器中的BOM和DOM

    BOM 浏览器对象模型 提供了独立于内容而与浏览器窗口进行交互的对象.描述了与浏览器进行交互的方法和接口,可以对浏览器窗口进行访问和操作,譬如可以弹出新的窗口,改变状态栏中的文本,对Cookie的支持 ...

  8. 4 HTML&JS等前端知识系列之Dom的基础

    preface 主要聊聊dom的编程,包含下面的内容: what's the dom dom选择器 innerText 替换或写入文本 value 获取input,select,textarea的值 ...

  9. 【JavaScript实用技巧(二)】Js操作DOM(由问题引发的文章改版,新人大佬都可)

    [JavaScript实用技巧(二)]Js操作DOM(由问题引发的文章改版,新人大佬都可!) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人 ...

随机推荐

  1. 4.深入TiDB:执行计划执行过程详解

    本文基于 TiDB release-5.1进行分析,需要用到 Go 1.16以后的版本 转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com/ ...

  2. mysql允许别人通过ip访问本机mysql数据

    要想允许别人通过ip访问本机mysql数据库,首先要是本机的mysql允许别的ip访问,也就是授权:其次别人的代码里,要写对本机的ip. 一.本机mysql的授权操作 1.cmd 进入控制台 2.输入 ...

  3. centos实现免密登陆及远程操作

    ----------------------------**********------------------------------------------------- 免密码登陆 第一步: 执 ...

  4. 华为云计算IE面试笔记-Fusionsphere架构及组件介绍(服务器虚拟化解决方案)

    eDSK   最上层则是eDSK是我们FusionSphere服务器虚拟化解决方案中的虚拟化北向统一API接口,其他的第三方系统或者是其他运营平台(FC.VMware等)可以通过eDSK轻松完成无缝对 ...

  5. 通过Python收集MySQL MHA 部署及运行状态信息的功能实现

    一. 背景介绍 当集团的MySQL数据库实例数达到2000+.MHA集群规模数百个时,对MHA的及时.高效管理是DBA必须面对的一个挑战.MHA 集群 节点信息 和 运行状态 是管理的基础.本篇幅主要 ...

  6. 深入理解JAVA虚拟机《二》

    对象.内存回收和垃圾收集算法 一.引用计数算法(不可靠) 现在很多比较普遍的判断对象是否存活的算法就是引用计数算法,其大概原理是:给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加1:当 ...

  7. == 和 equals区别

    == equals是两种字符串的方式 区别 == 是比较两个对象的引用地址值 equals是比较两个对象的具体内容 示例 package com.oop.demo06; public class De ...

  8. DistSQL:像数据库一样使用 Apache ShardingSphere

    Apache ShardingSphere 5.0.0-beta 深度解析的第一篇文章和大家一起重温了 ShardingSphere 的内核原理,并详细阐述了此版本在内核层面,特别是 SQL 能力方面 ...

  9. 题解 Crash 的文明世界

    题目传送门 题目大意 给出一个\(n\)个点的树,和常数\(k\),对于\(\forall i\in[1,n]\),求出: \[\sum_{j=1}^{n} \text{dist}(i,j)^k \] ...

  10. CAD_DWG图Web可视化一站式解决方案-唯杰地图-vjmap

    背景 DWG图是AutoCAD是私有格式,只能在CAD软件上编辑查看,如何发布至Web上做数据展示,GIS分析应用开发,一直是业内头疼的事情. 传统的办法采用的解析AutoCAD图形绘制,并封装成Ac ...