JavaScript笔记-系列
JavaScript基础笔记(1)
JavaScript基础笔记(2)
JavaScript基础笔记(3)
JavaScript笔记DOM操作
JavaScript—DOM案例
QX-AI
GPT-4
QX-AI初始化中...
本文介绍了JavaScript中操作DOM的方法和属性,包括获取DOM元素、操作元素内容和属性、操纵元素样式、处理表单元素、定时器和事件等。文章讲解了DOM树、节点类型和获取DOM元素的方法,并介绍了在JavaScript中获取页面滚动高度的属性和移动端的触摸事件。此外,本文深入探讨了事件流中的捕获阶段和冒泡阶段,并列举了一些获取元素尺寸、位置和节点操作的常用属性和方法。
介绍自己
生成预设简介
推荐相关文章
生成AI简介

DOM简介

HTML是一种纯文本格式的文件,也就是文档,HTML基础笔记

DOM:Document Object Model 文档对象模型,将 HTML 文档结构化表示

DOM 让网页 HTML 中的元素以树的方式呈现,并提供了访问、操控 DOM 树中各个节点的API,是为了让 JS 操作 HTML 元素而制定的一个规范,如今可看作是 JS 的一部分

每个载入浏览器的 HTML 文档都会成为 Document 对象,Document 对象是 Window 对象的一部分,可通过 window.document 或 document 对其进行访问

获取DOM对象
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Document</title>
</head>
<body>
<div>一个div</div>
<script>
console.log(document);
console.log(window.document);
</script>
</body>
</html>

控制台输出:获取到了网页所有元素,整个html文档

DOM树:
网页中的一切元素都是 DOM 树中的节点

节点类型:

  1. 文档节点:文档本身,整个 document 文档
  2. 元素节点:所有 HTML 标签元素,
  3. 属性节点:所有标签元素内的属性,id、class、href、name
  4. 文本节点:标签元素内的文本
  5. 注释节点:HTML中的注释,<!— 注释 —>

获取DOM元素

获取dom节点对象的方法:

  1. getElementById('id名') 根据id获取第一个dom对象(通常id唯一)
  2. getElementsByClassName('class类名') 根据class名获取dom对象数组 NodeList
  3. getElementsByTagName('标签名') 根据标签名获取dom对象数组
  4. getElementsByName('name名') 根据name属性值获取dom对象数组,一般不用
  5. querySelector('CSS选择器') 查找匹配指定CSS选择器的第一个dom对象
  6. querySelectorAll('CSS选择器') 查找匹配指定CSS选择器的所有元素,返回dom对象数组

获取到的dom对象数组都是伪数组

JS获取的都是对象,使用console.dir()能更直观地看一个对象。

操作元素的内容

获取到dom对象后,通过两个属性就能获取、修改元素中的内容

  1. innerText 不解析标签
  2. innerHTML 解析标签,通常用这个

使用 += 保留元素中原有内容,并在元素中末尾添加新内容

操作元素的属性

获取到dom对象后,直接访问属性(如src、href、id、class)就能进行修改或赋值

1
2
3
4
5
<img src="1.webp" alt="一张图片">
<script>
const img = document.querySelector('img');
img.src = "2.webp"
</script>

操控元素样式

1、通过 style 属性控制元素样式:css带有 - 连接符的属性,在js中采用小驼峰命名法获取

1
2
3
4
5
6
<div class="box"></div>
<script>
const box = document.querySelector('.box');
box.style.background = 'blue';
box.style.backgroundColor = 'green';//background-color
</script>

2、通过类名控制元素样式:直接修改style属性过于麻烦,可以先把样式写给一个类,再将类名赋给 className 属性,+= 保留原有类名

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<style>
.box1{
width: 100px;
height: 100px;
}
.box2{
width: 200px;
background: rgb(88, 164, 192);
}
</style>
<div class="box1"></div>
<script>
const box = document.querySelector('.box1');
box.className += ' box2';
</script>

使用 += 号来保留原有class还是不够规范

可以使用 classList 属性来添加、删除、切换(有就删除,没有就加上)类名

1
2
3
4
5
6
// 添加一个类名
元素.classList.add('类名');
// 删除一个类名
元素.classList.remove('类名');
// 切换一个类名
元素.classList.toggle('类名');

操作表单元素

input 标签框内的文本存放在其value属性中,获取即可

1
2
const ipt = document.querySelector('input');
console.log(ipt.value);

操作 input 的 type 属性,来控制输入框样式

1
2
const ipt = document.querySelector('input');
ipt.type = 'password';

一些布尔值的属性(赋任意值都代表true),disabled、checked、selected,添加上就有效果

1
2
const ipt = document.querySelector('input');
ipt.checked = true;

自定义属性

标准属性:标签自带的属性,class、id、title等

自定义属性:H5的新东西,以 data- 开头,格式 data-自定义后缀对象.dataset.自定义后缀 获取

1
2
3
4
5
<div class="box" data-id="123456"></div>
<script>
const box = document.querySelector('.box');
console.log(box.dataset.id);//123456
</script>

定时器

1、间歇函数 setInterval() 每隔一段时间自动执行一段代码

1
2
3
4
setInterval(()=>{
console.log(1);
},1000);
setInterval(fun,1000);

清除间歇函数定时器 clearInterval()

1
2
var itv = setInterval(fun,1000);
clearInterval(itv);

2、延时函数 setTimeout() 延时一段时间后执行代码

1
2
3
setTimeout(()=>{
console.log(1);
},1000);

清除延时函数定时器 clearTimeout()

事件

DOM事件:在文档或浏览器窗口中产生的一系列交互,如拖动元素、点击按钮、提交表单等。

JavaScript 以事件驱动为核心,通过监听事件或给事件绑定JS,可以在事件发生时执行特定 JS 以完成交互。

常见事件

这里都是事件名,属性名一般在事件名前加 on

鼠标事件:

  1. click 鼠标左键/键盘回车
  2. dbclick 双击鼠标左键
  3. mouseenter 光标移入元素,不冒泡
  4. mouseleave 光标移出元素,不冒泡
  5. mouseover 光标移入元素,冒泡
  6. mouseout 光标移出元素,冒泡
  7. mousedown 按下任意鼠标键
  8. mouseup 释放任意鼠标键
  9. mousewheel 鼠标滚轮滚动
  10. mousemove 光标在元素上移动

用户界面事件:

  1. load 页面或资源加载完成
  2. unload 卸载完成
  3. error JS出错或资源加载失败
  4. select 选中文字
  5. resize 调整窗口大小
  6. scroll 包含滚动条的元素

焦点事件:

  1. blur 失去焦点,不冒泡
  2. focus 获得焦点,不冒泡
  3. focusout 失去焦点,冒泡
  4. focusin 获得焦点,冒泡

键盘和输入事件:

  1. keydown 按下键盘某个键
  2. keyup 释放键盘某个键
  3. input 当输入框文本改变时立即触发
  4. change 当输入框内容发生改变,失去焦点时触发
  5. textInput 文本输入

HTML5事件:

  1. contextmenu 右键菜单
  2. beforeunload 页面卸载之前
  3. DOMContentLoaded DOM树构建完成
  4. readystatechange 加载状态变化
  5. hashchange URL散列值变化

事件的三要素:事件源、事件、事件驱动程序

事件源:触发事件的元素,获取事件源,即获取DOM节点
事件:JS定义的各种事件
事件驱动程序:触发事件后进行的操作

事件监听

使用 addEventListener 监听事件

1
元素对象.addEventListener('事件类型', 执行的函数)

可以重复绑定。

事件对象

事件对象存放了事件触发时的相关信息,如鼠标点击的位置坐标、键盘按下了哪个键

事件绑定的回调函数的第一个参数就是事件对象event、e

1
2
3
元素.addEventListener('事件',(e)=>{
console.lig(e);
});

事件对象常见属性:

  1. type 当前事件类型
  2. clientX 、 clientY 获取光标相对于浏览器可见窗口左上角的位置
  3. offsetX 、 offsetY 获取光标相对于当前DOM元素左上角的位置
  4. key 当前按下的键盘键的值
监听是否按下回车
1
2
3
4
const ipt = document.querySelector('input');
ipt.addEventListener('keyup', (e)=>{
if(e.key == 'Enter'){ console.log('回车'); };
});

常用事件

1、焦点事件 focus blur 见案例-搜索框下拉栏

2、键盘事件 keydown keyup input 见案例-评论发布、字数统计

3、mouseover 与 mouseenter
mouseover/mouseout 有冒泡效果,mouseenter/mouseleave 没有冒泡效果

使用mouseover,有冒泡效果,所以鼠标从监听的元素到其子元素,虽然子元素没用绑定鼠标进入事件,但该事件会冒泡到父元素的同名事件,所以也会触发进入

通常用 mouseenter/mouseleave

4、加载事件 load、DOMContentLoaded
load 监听某个元素内的所有资源(dom、css、img)加载完毕

1
2
3
4
//等待页面所有资源加载完毕,再执行回调函数
window.addEventListener('load', ()=>{})
//等待图片加载完毕
img.addEventListener('load', ()=>{})

DOMContentLoaded 监听HTML文档加载完毕该事件就被触发,不等待css等其它资源

1
document.addEventListener('DOMContentLoaded', ()=>{})

5、滚动事件 scroll
当某个元素的滚动条滚动时,触发该事件,不冒泡

通常配合元素的 scrollTopscrollLeft 两个属性,获取的是数字型,不带单位,但意思是像素px,可读写,可让js去控制滚动

1
2
3
4
//整个页面卷去的高度,document.documentElement获取html标签
document.documentElement.scrollTop
//元素被卷去的高度
div.scrollTop

这两个属性都用来获取被卷去的大小,即元素随着滚动超出可视窗口的大小(单位px)
scrollTop 滚动条往下,元素向上移动,即获取该元素向上移动超出可视区域的高度
scrollLeft 滚动条往右,元素向左移动,即获取该元素向左移动超出可视区域的宽度

获取页面滚动高度的时候优先考虑使用 window.pageYOffset 然后在使用scrollTop

1
2
var _scrollLeft = window.scrollX || window.pageXOffset || document.documentElement.scrollLeft
var _scrollTop = window.scrollY || window.pageYOffset || document.documentElement.scrollTop

一些小案例:

1
2
3
4
5
6
window.addEventListener('scroll', function () {
const n = document.documentElement.scrollTop
if (n >= 100) { // 页面滚动高度超过100px进行一些操作
} else { // 页面滚动高度小于100px进行恢复操作
}
})
回到顶部
1
2
3
4
5
6
const backTop = document.querySelector('#backTop')
backTop.addEventListener('click', function () {
// document.documentElement.scrollTop = 0
// window.scrollTo(x, y)
window.scrollTo(0, 0)
})

5、窗口尺寸变化事件 resize
浏览器窗口大小发生变化的时候触发的事件

1
window.addEventListener('resize', ()=>{})

6、移动端触摸事件 touchstart touchend touchmove

touchstart 手指触摸到元素时触发
touchend 手指从元素离开时触发
touchmove 手指在元素上滑动时触发

事件流

事件流:事件完整执行过程中的流动路径

两个阶段:捕获阶段、冒泡阶段

捕获阶段从父节点到子,冒泡阶段从子到父

处理函数默认在冒泡阶段执行,从子节点到父节点,依次向上调用所有父级元素的同名事件

让处理函数在捕获阶段触发:冒泡阶段不再触发

传入第三个参数true
1
元素.addEventListener(事件类型, 处理函数, true);

阻止冒泡:
默认存在冒泡模式,子元素触发事件也会触发父级同名事件,阻止冒泡能把事件限制在当前元素内

stopPropagation() 阻止事件流动传播,不仅能阻止冒泡也能阻止捕获

1
事件对象.stopPropagation();

解绑事件

removeEventListener() 对某个元素解绑某个处理函数,匿名、箭头函数无法被解绑

1
2
元素.removeEventListener(事件类型, 处理函数);
btn.removeEventListener('click', fn);

事件委托

事件委托:一种技巧,减少事件注册次数,提高程序性能。

事件冒泡可以用来实现事件委托,给父元素注册事件,当触发子元素的时候,会冒泡到父元素身上,从而触发父元素的事件。

案例:当多个子元素需要注册点击事件时,可以将点击事件注册到父元素上,再由父元素的事件对象e去找被点击的子元素,e.target 就能找到实际触发事件的子元素,再用其className、id、tagName 来确定业务上应该要触发事件的子元素。

1
2
3
4
5
6
const ul = document.querySelector('ul');
ul.addEventListener('click', function (e) {
if (e.target.tagName === 'LI') {
e.target.style.color = 'red'
}
})

阻止元素默认行为

使用 e.preventDefault() 阻止元素默认行为

让a标签点击不跳转链接
1
2
3
4
5
//<a href="http://www.baidu.com">百度一下</a>
const a = document.querySelector('a')
a.addEventListener('click', function (e) {
e.preventDefault()
})

元素的属性、方法

获取到元素后常用的属性和方法

元素的尺寸与位置

获取元素的宽高:clientWidthclientHeight两个属性,不包含padding、border,offsetWidthoffsetHeight包含padding、border

获取窗口的宽高:document.documentElement.clientWidth

offsetTopoffsetLeft获取元素距离自己最近一位带有定位的祖先元素的左、上位置

getBoundingClientRect() 获取元素的大小和相对于可视窗口的位置,返回一个对象里面有width、height、top等属性

元素节点操作

1、关系查找元素节点,以元素节点之间的关系进行查找,父找子、子找父、找兄弟

查找最近一级的父节点子元素.parentNode

查找最近一级的所有子节点,返回伪数组:父元素.children
firstElementChild 第一个子节点
lastElementChild 最后一个子节点

上一个兄弟节点:previousElementSibling
下一个兄弟节点:nextElementSibling

2、创建节点

document.createElement('标签名')

3、增加节点:

appendChild(插入的元素) 在指定节点的子节点列表末尾添加新的子节点

insertBefore(插入的元素,[放到哪个元素的前面]) 在节点的子节点列表任意位置前插入新的节点,默认在子节点列表的末尾插入

4、克隆节点

元素.cloneNode(布尔) 参数为true,后代节点也会被克隆,false克隆时不包含后代节点(即只克隆标签),默认false

5、删除节点

父元素.removeChild(子元素) 通过父节点删除子节点

BOM

BOM (Browser Object Model ) 是浏览器对象模型,提供了一些属性与方法

window对象

window对象是一个全局对象,是BOM的顶层对象,也是js中最顶级的对象,document、alert()、console、定时器等都是其属性和方法

所有通过var定义在全局作用域中的变量、函数都会变成window对象的属性和方法

window对象下的属性和方法调用的时候可以省略window

location对象

location拆分并保存了URL地址的各个组成部分

常见属性和方法

  1. href 获取完整的URL地址,也可以赋值进行地址跳转
  2. search 获取地址中携带的参数,?后面的部分
  3. hash 获取地址中的哈希值,#后面的部分
  4. reload() 刷新当前页面,传入参数true表示强制刷新

navigator保存了浏览器的相关信息

常见属性和方法

  1. userAgent 获取浏览器的类型、版本

history对象

history管理历史记录,如前进、后退、历史记录等

常见属性和方法

  1. back() 浏览器后退功能
  2. forward() 浏览器前进功能
  3. go() 参数1前进一个页面,-1后腿一个页面

本地存储

将数据存储这浏览器中,刷新页面不丢失数据,sessionStorage 和 localStorage,现在主要用localStorage

本地存储只能存字符串或数值型

localStorage 以键值对的形式存储,可以多页面共享
sessionStorage 以键值对的形式存储,生命周期为关闭浏览器就消失,数据同一个页面共享

新增/修改:setItem

1
localStorage.setItem(key, value);

读取:getItem

1
localStorage.getItem(key);

删除:removeItem

1
localStorage.removeItem(key);

存储复杂数据类型:存一个对象

由于本地存储只能存字符串,所以需要将对象先转为JSON字符串再存储,使用时再把JSON转为对象

JSON.parse() 将数据转换为 JavaScript 对象
JSON.stringify() 将 JavaScript 对象转换为 JSON 字符串

1
2
3
4
5
6
const obj = {
name: 'chuckle',
age: '19'
}
localStorage.setItem('obj', JSON.stringify(obj));
var obj2 = JSON.parse(localStorage.getItem('obj'));