从浏览器架构认识BOM和DOM
浏览器架构
JavaScript运行在浏览器,BOM就是连接JavaScript代码和浏览器的桥梁,而DOM就是用来操作各种标签元素的。
BOM包括 window、history、location、document ...
DOM包括 Document(整个文档)、Element(标签元素)、CharacterData(字符数据)、Attr(属性),这些元素又可以继续往下划分。

其中DOM元素、window对象都继承自EventTarget,所以它们都有EventTarget上的实例方法,而document是HTMLDocument的实例对象
console.log(window.__proto__);
console.log(window.__proto__.__proto__);
console.log(window.__proto__.__proto__.__proto__);
console.log(document.__proto__);
console.log(document.__proto__.__proto__);
console.log(document.__proto__.__proto__.__proto__);
console.log(document.__proto__.__proto__.__proto__.__proto__);

EventTarget
EventTarget有三个原型方法,在window和DOM元素上都可以使用
- addEventListener 给元素绑定事件
- removeEventListener 移除元素绑定的事件
- dispatchEvent 派发事件
给window对象绑定 "click" 点击事件
window.addEventListener('click', (event)=>{
console.log('屏幕被点击啦')
})
BOM
BOM主要包括以下几个对象
- window:包括全局、控制浏览器窗口相关的属性、方法
- history:浏览器曾经的会话历史记录
- location:访问的URL的信息
- document:当前窗口操作的文档对象
window
window在浏览器端有两个作用
一、作为全局对象
作为全局对象时,它主要有两个用途
- 通过var定义的变量将被挂载到window上
- 提供了全局方法 setTimeout、Math、Date
var user = "alice";
console.log(window.user);
window.setTimeout(() => {
console.log(window.setTimeout);
}, 0);

二、作为浏览器的窗口对象
作为浏览器的窗口对象承担着非常多的功能
- 包含大量的属性,localStorage、console、location、history、screenX、scrollX ...
- 包含大量的方法,alert、close、scrollTo、open ...
- 包含大量的事件,focus、blur、load、hashchange ...
- 包含从EventTarget继承 addEventListener、removeEventListener、dispatchEvent方法
window 的属性/方法/事件,可以省略window,直接使用其属性/方法/事件
console.log(window.screenX);
console.log(console);
scrollTo(200, 200);
window.onload = function () {
console.log("onload事件");
};

location
location中有大量关于url的信息,常用的是这些
- hash:锚点,url上#号后面的内容,可以用于页面中定位
- host:主机+端口号
- hostname:主机
- href:完整url链接
- pathname:路径
- port:端口号
- protocol:协议
在控制台上直接输入 location,可以获取到 location 对象的信息

location还有三个方法,也和url相关
- assign:跳转一个新的url页面
- replace:替代当前页面,不会被保存到历史记录中,表示不能通过后退按钮回到该页面
- reload:重新加载当前url的资源
history
history用来保存浏览器会话记录,可以通过history的方法跳转上、下一个页面
它有两个属性
- length:history栈的长度,表示保存了几条数据
- state:通过pushState/repleaceState 方法跳转保留的状态值
还有五个方法
- pushState:跳转某一地址,三个参数分别为保存的state,页面的title,跳转的url地址
- replaceState:替换当前地址
- go:前进/后退指定页,传入数字
- back:后退一页,相当于 go(-1)
- forward::前进一页,相当于go(1)
window.addEventListener("click", () => {
history.pushState({ name: "alice" }, null, "/home");
console.log(history.length);
console.log(history.state);
});

用一张图来总结BOM的用法

DOM
浏览器中有很多标签,DOM就是用来操作它们的。DOM元素都继承自EventTarget,所以它们都有实例上的属性方法,也继承自Node,同样具有Node的属性和方法。
Node再往下划分,就是各个DOM元素,它们有各自的特征
- Document:文档,包含HTMLDocument(html文档)、XMLDocument(xml文档)
- Element:标签元素,包含HTMLElement,HTMLElement又包含HTMLDivElement(div元素),HTMLImageElement(img元素)
- CharacterData:字符数据、文本,包含Text(标签中的内容)、Comment(注释)
- Attr:属性,比如 name,class
node
node是其它元素的父类,它所拥有的属性,子元素都有,以下几个属性和方法比较常见
- nodeName:节点名称
- nodeType:节点类型
- nodeValue:节点的值
- childNodes:所有子节点
- appendChild:方法,用于添加子元素
<div class="box">我是一个盒子</div>
const divEl = document.querySelector("div");
console.log(divEl.nodeName);
console.log(divEl.nodeType);
console.log(divEl.nodeValue);
console.log(divEl.childNodes);
console.log(divEl.childNodes[0].nodeValue);
console.log(document.nodeName);
console.log(document.nodeType);
console.log(document.nodeValue);
console.log(document.childNodes);
每一种元素类型有对应的nodeType,比如 element_node 对应type为1,text_node 对应type为3,comment_node对应type为8,document_node对应type为9;而nodeValue只有文本类型的数据有。

document
document 是Document的实例对象,代表整个html页面,当页面被浏览器解析完成,就会创建一个document对象。
document 中有非常多的标签,当我们创建一个html页面时,至少会有以下内容。

所以它的属性和方法都和标签元素有关
- body:获取body标签
- title:获取文档标题
- head:获取head标签
- children:获取所有子元素,HTMLCollection
- location:和window.location一样,拿到的是url信息

常用方法包括了创建、删除、获取元素
- createElement:创建元素
- removeElement:移除元素
- appendChild:继承自Node的属性,添加子元素
- querySelector:通过id/name/tagName获取单个元素
- querySelectorAll:通过id/name/tagName获取多个元素
- getElementById:通过Id获取元素
- getElementsByName:通过Name获取元素
- getElementsByTagName:通过TagName获取元素
// html 代码
<body>
<p></p>
<p></p>
// js代码
<script type="text/javascript">
const divEl = document.createElement("div");
const pEl = document.getElementsByTagName("p")[0];
const divTags = document.querySelectorAll("div");
document.body.appendChild(divEl);
document.body.removeChild(pEl);
console.log(pEl);
console.log(divTags);
</script>
</body>

element
element与单个标签元素有关,指的是具体的dom元素,它有这些常用属性和方法
- chidren:子元素
- childNodes:继承自Node的属性,子节点
- tagName:标签名
- id:id属性
- className:类名
- classList:由类名组成的数组
- clientWidth:元素宽度
- clientHeight:元素高度
- clientLeft:边框宽度
- clientTop:边框高度
- offsetWidth:距离左侧边距
- offsetTop:距离右侧边距
- getAttribute:方法,用于获取元素的某个属性
- setAttribute:方法,用于设置元素的某个属性
// html代码
<div id="element" class="box content"></div>
// css代码
.box {
height: 200px;
width: 200px;
border: 10px solid #000;
}
// js代码
const divEl = document.querySelector("div");
console.log(divEl.children);
console.log(divEl.childNodes);
console.log(divEl.tagName);
console.log(divEl.id);
console.log(divEl.className);
console.log(divEl.classList);
console.log(divEl.clientWidth, divEl.clientHeight);
console.log(divEl.clientLeft, divEl.clientTop);
console.log(divEl.offsetLeft, divEl.offsetTop);
console.log(divEl.getAttribute("id"));
divEl.setAttribute("name", "alice");

用一张图来总结DOM的用法

从浏览器架构角度去了解BOM和DOM就能更好的掌握,从而自如使用,以上就是BOM和DOM相关内容,关于js高级,还有很多需要开发者掌握的地方,可以看看我写的其他博文,持续更新中~
从浏览器架构认识BOM和DOM的更多相关文章
- 浏览器中的BOM和DOM
BOM 浏览器对象模型 提供了独立于内容而与浏览器窗口进行交互的对象.描述了与浏览器进行交互的方法和接口,可以对浏览器窗口进行访问和操作,譬如可以弹出新的窗口,改变状态栏中的文本,对Cookie的支持 ...
- JavaScript学习总结(一)——ECMAScript、BOM、DOM(核心、浏览器对象模型与文档对象模型)
一.JavaScript简介 JavaScript是一种解释执行的脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型,它遵循ECMAScript标准.它的解释器被称为JavaScript引 ...
- 浏览器内核与BOM对象介绍
BOM(Browser Object Model)对象介绍 我们都知道js有三部分组成,ECMAScript.DOM和BOM,根据宿主(浏览器)的不同,具体的表现形式也不尽相同,ie和其它浏览器也是风 ...
- BOM,DOM,ECMAScripts三者的关系
一:DOM 文档对象模型(DOM)是表示文档(比如HTML和XML)和访问.操作构成文档的各种元素的应用程序接口(API) DOM是HTML与JavaScript之间沟通的桥梁. DOM下,HTM ...
- bom和dom总结
BOM1.1 介绍 1.BOM是browser object model的缩写,简称浏览器对象模型 2.BOM提供了独立于内容而与浏览器窗口进行交互的对象 3.由于BOM主要用 ...
- BOM和DOM的区别和关联
BOM 1. BOM是Browser Object Model的缩写,即浏览器对象模型. 2. BOM没有相关标准. 3. BOM的最根本对象是window. 从1可以看出来:BOM和浏览器关系密切. ...
- 浏览器对象模型(BOM,Browser Object Model)
本文内容 1.概述 2.windows与document 3.对话框 4.定时调用 5.URL解析与访问历史 6.浏览器和屏幕信息 ★概述 &q ...
- 实现JavaScript的组成----BOM和DOM
我们知道,一个完整的JavaScript的实现,需要由三部分组成:ECMAScript(核心),BOM(浏览器对象模型),DOM(文档对象模型). 今天主要学习BOM和DOM. BOM: BOM提供了 ...
- JavaScript的组成—ECMAScript、BOM和DOM
JavaScript 是一种基于 ECMAScript 规范的脚本语言,并在此基础上进行了自己的封装.ECMAScript 不是一种编程语言,仅仅是一种脚本语言规范,由欧洲计算机协会制定和发布,任 ...
- BOM和DOM详解
DOM介绍 D(文档)可以理解为整个Web加载的网页文档,O(对象)可以理解为类似window对象只来的东西,可以调用属性和方法,这里我们说的是document对象,M(模型)可以理解为网页文档的树形 ...
随机推荐
- OData WebAPI实践-Non-EDM模式
前文说到了 EDM 与 OData 之间的关系,具有 EDM 的 OData 提供了强大的查询能力,但是 OData 并不必须要配置 EDM,我们也可以使用 Non-EDM 方案. Non-EDM 所 ...
- 2022-04-24:位集 Bitset 是一种能以紧凑形式存储位的数据结构。 请你实现 Bitset 类。 Bitset(int size) 用 size 个位初始化 Bitset ,所有位都是 0
2022-04-24:位集 Bitset 是一种能以紧凑形式存储位的数据结构. 请你实现 Bitset 类. Bitset(int size) 用 size 个位初始化 Bitset ,所有位都是 0 ...
- DataGridViewImageColumn 图片照片
Private Sub BT_PHOTOADDRESS_Click(sender As Object, e As EventArgs) Handles BT_PHOTOADDRESS.Click Di ...
- linux中使用jenkins自动部署前端工程
1.去年在自己的服务器上安装了jenkins,说用来自己研究一下jenkins自动化部署前端项目,jenkins安装好了,可是一直没管,最近终于研究了一下使用jenkins自动化部署,以此记录下来. ...
- WPF 入门笔记 - 01 - 入门基础以及常用布局
本篇为学习博客园大佬圣殿骑士的<WPF基础到企业应用系列>以及部分DotNet菜园的<WPF入门教程系列>所作笔记,对应圣殿骑士<WPF基础到企业应用系列>第 1 ...
- 警惕看不见的重试机制:为什么使用RPC必须考虑幂等性
0 文章概述 在RPC场景中因为重试或者没有实现幂等机制而导致的重复数据问题,必须引起大家重视,有可能会造成例如一次购买创建多笔订单,一条通知信息被发送多次等问题,这是技术人员必须面对和解决的问题. ...
- 微软New Bing Chat AI聊天免费体验(需要魔法~)
必应聊天是什么? Bing Chat是一个AI 聊天机器人,它可以理解您问题的上下文并以人性化的方式回复.Microsoft 已将此功能直接集成到Bing 搜索中,使 Bing 成为搜索结果和AI 支 ...
- 在树莓派上实现numpy的LSTM长短期记忆神经网络做图像分类,加载pytorch的模型参数,推理mnist手写数字识别
这几天又在玩树莓派,先是搞了个物联网,又在尝试在树莓派上搞一些简单的神经网络,这次搞得是LSTM识别mnist手写数字识别 训练代码在电脑上,cpu就能训练,很快的: import torch imp ...
- BFF层聚合查询服务异步改造及治理实践 | 京东云技术团队
首先感谢王晓老师的[接口优化的常见方案实战总结]一文总结,恰巧最近在对稳健理财BFF层聚合查询服务优化治理,针对文章内的串行改并行章节进行展开,分享下实践经验,主要涉及原同步改异步的过程.全异步化后衍 ...
- 三分钟免费将 Claude API 接入个人服务
首先我们介绍一下今天的主角 Claude Claude 是最近新开放的一款 AI 聊天机器人,是世界上最大的语言模型之一,比之前的一些模型如 GPT-3 要强大得多,因此 Claude 被认为是 Ch ...