【浏览器】聊聊DOM
【浏览器】聊聊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元素的CURD,CURD
在看各位没有不熟悉,没有不兴奋的吧。
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的属性和方法
DOM 4 警告!
在 W3C DOM Core 中,Attr (attribute) 对象从 Node 对象继承所有属性和方法。
在 DOM 4 中,Attr 对象不再从 Node 继承。为了保证未来的代码安全,应该避免在属性对象上使用节点对象的属性和方法。
NamedNodeMap 对象
在 HTML DOM 中,NamedNodeMap 对象表示元素属性节点的无序集合,NamedNodeMap 中的节点可通过名称或索引(数字)来访问。
Text对象
Text 对象代表 HTML 表单中的文本输入域,该元素可创建一个单行的文本输入字段。当用户编辑显示的文本并随后把输入焦点转移到其他元素的时候,会触发 onchange 事件句柄。
Text的属性和方法
Comment对象
Comment是注释对象,在对HTML编码时,总会有一些注释,但是注释的代码,众所周知,是没有被执行的。在HTML中,它就存放在Comment对象中。
createComment() 方法可创建注释节点,一般对这个对象的操作比较的少,也没啥地址可贴的了。
最后说的话
在写这篇文章的时候,我一直在思考有没有必要写这样的一篇文章,其实感觉写这样的文章很难,尽管大多数是一些标准和协议,但往往就是这些标准和协议难以突破,同时自己也在慢慢积累与沉淀,能沉下心写,甚至抄点基础的东西,补足那个圆的一节,感觉会很踏实很多。
本文也是第二次扩写,从500到1500。有机会,或者再有累计的话再扩写吧,到时希望在这些标准之上有所突破哈。
感谢
万能的网络
公众号-归子莫,小程序-小归博客
【浏览器】聊聊DOM的更多相关文章
- Javascript 强制浏览器渲染Dom文档
在Cordova+Framework7开发Hybrid App时,在iPhone 7上遇到一个诡异的现象(Chrome浏览器.Android都正常):js修改手风琴中的input文本框的值后,但页面仍 ...
- Chrome浏览器控制台[DOM] Password field is not contained in a form:
[DOM] Password field is not contained in a form: ( [DOM]密码字段不包含在form表单中) 解决方案:添加一层form标签 <div cla ...
- 浏览器兼容——DOM事件封装函数
//封装函数var eventUtil={ //添加事件 addHandler:function(element,type,handler){ if(element.addE ...
- DOM对象本身也是一个js对象,所以严格来说,并不是操作这个对象慢,而是说操作了这个对象后,会触发一些浏览器行为(转)
一直都听说DOM很慢,要尽量少的去操作DOM,于是就想进一步去探究下为什么大家都会这样说,在网上学习了一些资料,这边整理出来. 首先,DOM对象本身也是一个js对象,所以严格来说,并不是操作这个对象慢 ...
- 转---JS 一定要放在 Body 的最底部么?聊聊浏览器的渲染机制
作者:德来 segmentfault.com/a/1190000004292479 如有好文章投稿,请点击 → 这里了解详情 一.从一个面试题说起 面试前端的时候我喜欢问一些看上去是常识的问题.比如: ...
- DOM,浏览器,javascript,html之间的关系
来源于:https://github.com/hucheng91/myBlog/blob/master/web/dom/dom.md DOM定义 DOM可以以一种独立于平台和语言的方式访问和修改一个文 ...
- 浏览器中的BOM和DOM
BOM 浏览器对象模型 提供了独立于内容而与浏览器窗口进行交互的对象.描述了与浏览器进行交互的方法和接口,可以对浏览器窗口进行访问和操作,譬如可以弹出新的窗口,改变状态栏中的文本,对Cookie的支持 ...
- 4 HTML&JS等前端知识系列之Dom的基础
preface 主要聊聊dom的编程,包含下面的内容: what's the dom dom选择器 innerText 替换或写入文本 value 获取input,select,textarea的值 ...
- 【JavaScript实用技巧(二)】Js操作DOM(由问题引发的文章改版,新人大佬都可)
[JavaScript实用技巧(二)]Js操作DOM(由问题引发的文章改版,新人大佬都可!) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人 ...
随机推荐
- Shell系列(31)- 双分支if语句简介
双分支if条件语句 if [ 条件判断式 ] then 条件成立,执行的程序 else 条件不成立,执行的程序 fi 需求 根据用户输入的目录名,判断是否存在 脚本: #!/bin/bash #使用r ...
- SpringBoot 整合 Elastic Stack 最新版本(7.14.1)分布式日志解决方案,开源微服务全栈项目【有来商城】的日志落地实践
一. 前言 日志对于一个程序的重要程度不用过多的言语修饰,本篇将以实战的方式讲述开源微服务全栈项目 有来商城 是如何整合当下主流日志解决方案 ELK +Filebeat . 话不多说,先看实现的效果图 ...
- dubbo微服务架构
架构 节点角色说明 调用关系说明 服务容器负责启动,加载,运行服务提供者. 服务提供者在启动时,向注册中心注册自己提供的服务. 服务消费者在启动时,向注册中心订阅自己所需的服务. 注册中心返回服务提供 ...
- Python中类-带括号与不带括号的区别
类不带括号我们叫赋值,带括号我们叫实例化. 什么是赋值? a=7 b=a id(7) 140726814208448 id(a) 140726814208448 id(b) 1407268142084 ...
- three.js 添加html内容、文本
需求: 1.在场景内添加html元素并动态更新 2.html内容需跟随场景变化 方案: 新加方案:https://www.zhihu.com/question/49929467/answer/1186 ...
- VueCLI3 创建vue项目
关于旧版本 Vue CLI 的包名称由 vue-cli 改成了 @vue/cli. 如果你已经全局安装了旧版本的 vue-cli (1.x 或 2.x),你需要先通过 npm uninstall vu ...
- 【C++ Primer Plus】编程练习答案——第2章
1 void ch2_1() { 2 using namespace std; 3 cout << "xxxxxxxx" << endl; 4 } 5 6 ...
- Go语言之数组与切片基础
一.数组 数组是同一类型元素的集合,可以放多个值,但是类型一致,内存中连续存储 Go 语言中不允许混合不同类型的元素,而且数组的大小,在定义阶段就确定了,不能更改 1.数组的定义 // 定义一个大小为 ...
- 安装Transformers与ValueError: Unable to create tensor, you should probably activate truncation and/or padding with 'padding=True' 'truncation=True' to have batched tensors with the same length.报错
此篇博客内容为短暂存留记录(项目使用过程还未记录),后续将会更新完整学习流程.. 1.根据官网上的链接安装有两种方式: (1)pip直接安装 pip install transformers # 安装 ...
- C#开发BIMFACE系列44 服务端API之计算图纸对比差异项来源自哪个图框
BIMFACE二次开发系列目录 [已更新最新开发文章,点击查看详细] 在前两篇博客<C#开发BIMFACE系列42 服务端API之图纸对比>.<C#开发BIMFACE系列43 ...