JavaScript之彻底搞懂DOM与BOM及其区别与用法(1)

本文详细介绍了DOM(DocumentObjectModel)中创建、增添和删除节点的方法,以及DOM的一些常见属性。同时概述了BOM(BrowserObjectModel)的概念,重点讲解了window和location对象及其常用属性和方法。旨在帮助前端开发者掌握浏览器操作的核心技术。
摘要由CSDN通过智能技术生成

🌳 创建节点(Node)的DOM方法

//1.创建一个html的元素,传参是元素类型,例如div、h1-5、a,下以div为例

var element = document.createElement(“div”)

//2.创建一个文本节点,传参的是对应的文本内容(注意是文本节点,不是某个html元素)

var text_node = document.createTextNode(text)

//3.创建一个属性节点,传参是对应的属性名

var attr_node = document.createAttribute(attribute_name)

element.setAttributeNode(attr_node)

特别注意第三个,创建属性节点这个方法,要搭配具体的元素,也就是你要先获取某个具体元素element,创建一个属性节点,最后对这个元素添加这个属性节点(setAttributeNode)


🌳 增添节点的DOM方法

//1.向element内部的最后面添加一个节点,传入的参数是节点类型

element.appendChild(Node)

//2.向element内部某个已存在的节点的前面插入一个节点,仍然传入一个节点类型的参数

element.insertBefore(new_Node,existed_Node)

注意,添加节点之前,你要先创建好节点,同时要选好父节点element第二个方法甚至你还要找好插入位置后面的兄弟节点


🌳 删除节点的DOM方法

//删除element内的某个节点,传参是节点类型参数

element.removeChild(Node)

注意,删除时,要找到对应的父节点element才可以顺利删除


🌳 DOM常见的一些属性

最后是一些常见的DOM属性

//1.获取当前元素的父节点

var element_father = element.parentNode

//2.获取当前元素的html元素型子节点

var element_son = element.children

//3.获取当前元素的所有类型子节点,包括html元素、文本和属性

var element_son = element.childNodes

//4.获取当前元素的第一个子节点

var element_first = element.firstChild

//5.获取当前元素的前一个同级元素

var element_pre = element.previousSibling

//6.获取当前元素的后一个同级元素

var element_next = element.nextSibling

//7.获取当前元素的所有文本,包括html源码和文本

var element_innerHTML = element.innerHTML

//8.获取当前元素的所有文本,不包含html源码

var element_innerTEXT = element.innerText

其中,第七个的意思是说把元素内的html代码和文本都转成文本,原先的html代码是执行的,转成文本相当于变成了普通的字符串!


III. BOM及其相关操作

==============

III.I BOM总述


下面我们再讲一讲BOM,由于篇幅有限,BOM不做特别细致的讲解(实用性的确也没有DOM那么大)。我们回顾一下开始的时候关于BOM的介绍

BOM给JavaScript提供用来操作浏览器的若干的"方法"

那么首先我们用一张图把整个BOM的结构给大家梳理一下,与DOM类似,BOM也有一个树状结构:


III.II BOM常见对象的介绍


🌳window对象

从上面这张图上,我们可以看到:

window是整个BOM树食物链的顶端,因此每一个新打开的窗口,都被认为是一个window对象。

window对象有以下常见的属性和方法

属性/方法含义
opener当前窗口的父窗口
length窗口中的框架数
document窗口中当前显示的文档对象
alert(string)创建一个警告对话框,显示一条信息
close()关闭窗口
confirm()创建一个需要用户确认的对话框
open(url,name,[options])打开一个新窗口并返回新 window 对象
prompt(text,defaultInput)创建一个对话框要求用户输入信息
setInterval(expression,milliseconds)经过指定时间间隔计算一个表达式
setInterval(function,millis enconds,[arguments])经过指定时间间隔后调用一个函数
setTimeout(expression,milli seconds)在定时器超过后计算一个表达式
setTimeout(expression,milli seconds,[arguments])在定时器超过时后计算一个函数

其中,大家看到上面有一个函数alert(),因为大家学JavaScript的时候,输入输出流大家大部分都以alert()函数弹窗作为自己的第一个demo,所以看到这里你可能会问了:

当时用alert()函数的时候,好像没有提到window,那这里的alert()是之前学的那个alert()吗?答案是这样的:

两个alert()确实是同一个函数,之所以可以不加window是因为,window的所有属性和方法,都可以有两种表示方法

(1) window.属性 / window.方法()

(2) 直接属性 / 方法() 的方式调用

不仅仅是alert(),上面所有的window属性和函数都成立,感兴趣的小伙伴可以自行尝试。


🌳location对象

什么是location对象?

location对象是window对象的一个属性,提供了与当前窗口中加载的文档有关的信息,还提供了一些导航功能。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

更多面试题

**《350页前端校招面试题精编解析大全》**内容大纲主要包括 HTML,CSS,前端基础,前端核心,前端进阶,移动端开发,计算机基础,算法与数据结构,项目,职业发展等等

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!**](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值