变量声明
有变量先给const,如果后面发现它是要被修改的,再改为let
一、Web API基本认知
1.1 作用和分类
作用:使用js操作HTML和浏览器
分类:DOM(文档对象模型-控制标签)BOM(浏览器对象模型-)
1.2 DOM
Document Object Model--用来呈现以及与任意HTML或XML文档交互的API
即操作网页内容
作用:开发网页特效实现和用户的交互
1.3 DOM树
将HTML以树状结构直观的表达出来,称之为文档树或DOM树
直观的体现了标签与标签的关系
1.4 DOM对象
浏览器根据html标签生成的js对象
即把html中的标签当作js中的对象来处理
document对象
网页所有内容都在document里面,它提供的属性和方法用来访问和操作网页内容
二、获取DOM对象
2.1 根据CSS选择器来获取DOM元素
1.选择匹配的第一个元素
//字符串中的写法和css选择器一致
//返回的是一个对象
//可以直接修改操作
const box = document.querySelector('div') //按照标签选择
const box = document.querySelector('.box') //按照类选择
const box = document.querySelector('#nav') //按照id选择
2.选择匹配的所有元素
//返回一个对象数组
//遍历修改操作
const liArr = document.querySelectorAll('ul li')
//得到的是伪数组
//有长度索引号,但是没有pop() push()等方法
for(let i=0; i < liArr.length; i++){
console.log(liArr[i])
}
三、操作元素内容
修改元素的文本更换内容
3.1 对象.innerText
<div class="box">我是文字内容</div>
<script>
const box = document.querySelector('.box')
console.log(box.innerText)
//innerText不解析标签 只能显示纯文本
box.innerText = '我的内容变了'
console.log(box.innerText)
</script>
3.2 对象.innerHTML
//解析标签
box.innerHTML = '<strong>我要变粗</strong>'
console.log(box.innerHTML)
案例-年会抽奖
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.wrapper{
width: 480px;
height: 420px;
margin: 100px auto;
box-sizing: border-box;
}
span{
display: inline-block;
}
</style>
</head>
<body>
<div class="wrapper">
<strong>年会抽奖</strong>
<h1>一等奖:<span id="one">??</span></h1>
<h3>二等奖:<span id="two">??</span></h3>
<h5>三等奖:<span id="three">??</span></h5>
</div>
<script>
const personArr = ['小麦','小黑','小白','小红','小明','小张','小何','小程']
function selectPrice(arr,id){
let rand = Math.floor(Math.random()*arr.length)
let span = document.querySelector(id)
span.innerHTML = arr[rand]
arr.splice(rand,1)
}
selectPrice(personArr,'#one')
selectPrice(personArr,'#two')
selectPrice(personArr,'#three')
</script>
</body>
</html>
四、操作元素属性
4.1 操作元素常用属性
常见属性:href / title /src
对象.属性 = 值
<img src="./images/1.webp" alt="">
<script>
const img = document.querySelector('img')
img.src = './images/2.webp'
img.title = 'pink老师的艺术照'
</script>
4.2 操作元素样式属性
1. 通过style属性操作css
对象.style.样式属性 = 值
const box = document.querySelector('.box')
//修改元素样式
box.style.width = '200px'
//有连接符-的属性采用小驼峰命名法
box.style.marginTop = '15px'
box.style.backgroundColor = 'pink'
2.通过操作类名操作css
元素.className = '类名'
同时修改多个类名,直接使用会覆盖以前的类名
3. 通过classList操作css
追加和删除类名
element.classList.add('类名') //追加一个类
element.classList.remove('类名') //删除一个类
element.classList.toggle('类名') //切换一个类 有就删掉 没有就加上
4.3 操作表单元素属性
<input type="checkbox">
<button>按钮</button>
<script>
const ipt = document.querySelector('input')
ipt.checked = true
const bt = document.querySelector('button')
bt.disabled = true
</script>
4.4 自定义属性
data- 开头的都是自定义属性
DOM上以dataset对象方式获取
<div data-id="1" data-spm="dd">1</div>
<script>
const one = document.querySelector('div')
console.log(one.dataset.id)
</script>
五、定时器-间歇函数
网页中每隔一段时间自动执行一段代码
//开启定时器
setInterval(函数名, 间隔时间)
//函数名不能加小括号
//关闭定时器
let 变量名 = setInterval(函数名, 间隔时间)
clearInterval(变量名)
综合案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>轮播图点击切换</title>
<style>
* {
box-sizing: border-box;
}
.slider {
width: 560px;
height: 400px;
overflow: hidden;
}
.slider-wrapper {
width: 100%;
height: 320px;
}
.slider-wrapper img {
width: 100%;
height: 100%;
display: block;
/* transition: all 1s; */
}
.slider-footer {
height: 80px;
background-color: rgb(100, 67, 68);
padding: 12px 12px 0 12px;
position: relative;
}
.slider-footer .toggle {
position: absolute;
right: 0;
top: 12px;
display: flex;
}
.slider-footer .toggle button {
margin-right: 12px;
width: 28px;
height: 28px;
appearance: none;
border: none;
background: rgba(255, 255, 255, 0.1);
color: #fff;
border-radius: 4px;
cursor: pointer;
}
.slider-footer .toggle button:hover {
background: rgba(255, 255, 255, 0.2);
}
.slider-footer p {
margin: 0;
color: #fff;
font-size: 18px;
margin-bottom: 10px;
}
.slider-indicator {
margin: 0;
padding: 0;
list-style: none;
display: flex;
align-items: center;
}
.slider-indicator li {
width: 8px;
height: 8px;
margin: 4px;
border-radius: 50%;
background: #fff;
opacity: 0.4;
cursor: pointer;
}
.slider-indicator li.active {
width: 12px;
height: 12px;
opacity: 1;
}
</style>
</head>
<body>
<div class="slider">
<div class="slider-wrapper">
<img src="./image/slider01.jpg" alt="" />
</div>
<div class="slider-footer">
<p>对人类来说会不会太超前了?</p>
<ul class="slider-indicator">
<li class="active"></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<div class="toggle">
<button class="prev"><</button>
<button class="next">></button>
</div>
</div>
</div>
<script>
// 1. 初始数据
const sliderData = [
{ url: './image/slider01.jpg', title: '对人类来说会不会太超前了?', color: 'rgb(100, 67, 68)' },
{ url: './image/slider02.jpg', title: '开启剑与雪的黑暗传说!', color: 'rgb(43, 35, 26)' },
{ url: './image/slider03.jpg', title: '真正的jo厨出现了!', color: 'rgb(36, 31, 33)' },
{ url: './image/slider04.jpg', title: '李玉刚:让世界通过B站看到东方大国文化', color: 'rgb(139, 98, 66)' },
{ url: './image/slider05.jpg', title: '快来分享你的寒假日常吧~', color: 'rgb(67, 90, 92)' },
{ url: './image/slider06.jpg', title: '哔哩哔哩小年YEAH', color: 'rgb(166, 131, 143)' },
{ url: './image/slider07.jpg', title: '一站式解决你的电脑配置问题!!!', color: 'rgb(53, 29, 25)' },
{ url: './image/slider08.jpg', title: '谁不想和小猫咪贴贴呢!', color: 'rgb(99, 72, 114)' },
]
const img = document.querySelector('.slider-wrapper img')
const p = document.querySelector('.slider-footer p')
let i = 0
setInterval(function(){
i++
if(i > sliderData.length) i = 0
img.src = sliderData[i].url
p.innerHTML = sliderData[i].title
document.querySelector(`.slider-indicator .active`).classList.remove('active')
document.querySelector(`.slider-indicator li:nth-child(${i + 1})`).classList.add('active')
},1000)
</script>
</body>
</html>