思维导图
data:image/s3,"s3://crabby-images/8d9bc/8d9bc52b5542f49443e926755655e4637e8d167e" alt=""
Bom操作
data:image/s3,"s3://crabby-images/d63ac/d63ac51fec4abadb9dc07a9286d3ad839eb058cf" alt=""
一、Window对象
1.1 BOM(浏览器对象模型)
data:image/s3,"s3://crabby-images/639b8/639b84aa9cda8b7b85cd5de221ade6fae4d7056c" alt=""
html
<!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>
</head>
<body>
<script>
// document.querySelector()
// window.document.querySelector()
console.log(document === window.document)
function fn() {
console.log(11)
}
window.fn()
var num = 10
console.log(window.num)
</script>
</body>
</html>
1.2 定时器-延时函数
data:image/s3,"s3://crabby-images/4e23a/4e23ae7ff0c8a099912d7a48d30a5be00371187c" alt=""
data:image/s3,"s3://crabby-images/e5afb/e5afb3bf2b4f44ee779ab4741b4318e4a75f5384" alt=""
data:image/s3,"s3://crabby-images/e2f5e/e2f5ef1b55218d2190527a98fae74eef709983a3" alt=""
html
<!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>
</head>
<body>
<script>
setTimeout(function () {
console.log('时间到了')
}, 2000)
</script>
</body>
</html>
1.3 JS 执行机制
data:image/s3,"s3://crabby-images/82444/824441a12bc7b3393cd0db9c230c0794d95e8f36" alt=""
data:image/s3,"s3://crabby-images/4b499/4b499315b5c52c66723260f27b01bc3d94741fd0" alt=""
data:image/s3,"s3://crabby-images/be3c3/be3c3b9b6a2a3c662c2f7e0e0bcae1a18a8fefad" alt=""
data:image/s3,"s3://crabby-images/e7889/e7889d58d566cfea18ef417e01a08d2eddb53877" alt=""
data:image/s3,"s3://crabby-images/32380/3238041749657dc85c13008cad1619cb909a2ff8" alt=""
data:image/s3,"s3://crabby-images/798d5/798d54a99a51527b9a31e78ae8210d4cce631d34" alt=""
1243或1234
data:image/s3,"s3://crabby-images/5dd75/5dd750ee28f9a78534b0ff0e4879dc62dd2791ec" alt=""
1.4 location对象
data:image/s3,"s3://crabby-images/d4864/d4864e5e611ca54fcfcc36bf3f25a04f142fd628" alt=""
location的href属性(可读写)实现页面跳转:
data:image/s3,"s3://crabby-images/3bb08/3bb0850029c23e5bb6b8edb5c58ae136c4171d08" alt=""
data:image/s3,"s3://crabby-images/404ab/404abdae7bc1a8d0aa2dd0515bc1540d4d0d9e1a" alt=""
html
<!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>
span {
color: red;
}
</style>
</head>
<body>
<a href="http://www.itcast.cn">支付成功<span>5</span>秒钟之后跳转到首页</a>
<script>
// 1. 获取元素
const a = document.querySelector('a')
// 2.开启定时器
// 3. 声明倒计时变量
let num = 5
let timerId = setInterval(function () {
num--
a.innerHTML = `支付成功<span>${num}</span>秒钟之后跳转到首页`
// 如果num === 0 则停止定时器,并且完成跳转功能
if (num === 0) {
clearInterval(timerId)
// 4. 跳转 location.href
location.href = 'http://www.itcast.cn'
}
}, 1000)
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/6c2d8/6c2d83ea7ce2bbfc6c7d4cdf268fc3b7643b254f" alt=""
data:image/s3,"s3://crabby-images/12e09/12e09fb74fcfbd5d8617ff75f20bac823d359e72" alt=""
data:image/s3,"s3://crabby-images/e916d/e916de7354818a108695cb74d9fdf233f19065d8" alt=""
html
<!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>
</head>
<body>
<form action="">
<input type="text" name="username">
<input type="password" name="pwd">
<button>提交</button>
</form>
<a href="#/my">我的</a>
<a href="#/friend">关注</a>
<a href="#/download">下载</a>
<button class="reload">刷新</button>
<script>
// console.log(window.location)
// console.log(location)
// console.log(location.href)
// 1. href 经常用href 利用js的方法去跳转页面
// location.href = 'http://www.baidu.com'
const reload = document.querySelector('.reload')
reload.addEventListener('click', function () {
// f5 刷新页面
// location.reload()
// 强制刷新 ctrl+f5
location.reload(true)
})
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/fe3da/fe3da9383737469b0a14ce2d82933964a303691a" alt=""
data:image/s3,"s3://crabby-images/74fe3/74fe3fc620749c09e5131367f6c210577294056f" alt=""
data:image/s3,"s3://crabby-images/60bb6/60bb63e38bef8824f4ce71e00186a9f3ba8f639c" alt=""
1.5 navigator对象
data:image/s3,"s3://crabby-images/6eb80/6eb8086500b38658e20c3cd3e5ff715ed862bd72" alt=""
立即执行函数如果写成 function(){}() 会报错,
可以写成 (function(){})()
也可以写成 !function(){}() 或者+function(){}() ~function(){}()
data:image/s3,"s3://crabby-images/6a0db/6a0dba548762d77b542c3f12ed61f7bbf3ca46f1" alt=""
1.6 histroy对象
data:image/s3,"s3://crabby-images/827cd/827cdc41f87446d69880b6b331635c8285c4b592" alt=""
二、本地存储
2.1 本地存储介绍
data:image/s3,"s3://crabby-images/e47c9/e47c93b5d54682cee59ce133557f79285dfb96a0" alt=""
2.2 本地存储分类- localStorage
data:image/s3,"s3://crabby-images/ad1a2/ad1a2f037c2b5d79a83667862be4119abc06456d" alt=""
data:image/s3,"s3://crabby-images/21454/214543ca9aa2ca206abc1c9130e1f6a147a4b94a" alt=""
data:image/s3,"s3://crabby-images/cb3e2/cb3e21782998f032418d39b1fa5604f4653e71ea" alt=""
html
<!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>
</head>
<body>
<script>
// 1. 要存储一个名字 'uname', 'pink老师'
// localStorage.setItem('键','值')
localStorage.setItem('uname', 'pink老师')
// 2. 获取方式 都加引号
console.log(localStorage.getItem('uname'))
// 3. 删除本地存储 只删除名字
// localStorage.removeItem('uname')
// 4. 改 如果原来有这个键,则是改,如果么有这个键是增
localStorage.setItem('uname', 'red老师')
// 我要存一个年龄
// 2. 本地存储只能存储字符串数据类型
localStorage.setItem('age', 18)
console.log(localStorage.getItem('age'))
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/0bf60/0bf60688499eba54e8aa86a669e986a3ed5118c8" alt=""
2.2 本地存储分类- sessionStorage
data:image/s3,"s3://crabby-images/971dd/971dd461ded76698fd2bb8ba132c48ec45fc1a61" alt=""
2.3 存储复杂数据类型
data:image/s3,"s3://crabby-images/77751/7775148749f87de1f6bff955c3a212d397b401a8" alt=""
data:image/s3,"s3://crabby-images/178fd/178fd8adbe39c4c8f6c5c1981032f21dfb2de0f3" alt=""
只能存储字符串类型
data:image/s3,"s3://crabby-images/d082f/d082f71aef88394aaec5c13620d3246cb5947bd4" alt=""
data:image/s3,"s3://crabby-images/d61fb/d61fb96d5eb858e3408050bc2fb43725cf212426" alt=""
data:image/s3,"s3://crabby-images/6051e/6051e7d0f85a1c2d5699eb1eb81e110062d9b671" alt=""
data:image/s3,"s3://crabby-images/5d9da/5d9da9639b2cb59952186799b11b72527ffb7a01" alt=""
html
<!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>
</head>
<body>
<script>
const obj = {
uname: 'pink老师',
age: 18,
gender: '女'
}
// // 存储 复杂数据类型 无法直接使用
// localStorage.setItem('obj', obj) [object object]
// // 取
// console.log(localStorage.getItem('obj'))
// 1.复杂数据类型存储必须转换为 JSON字符串存储
localStorage.setItem('obj', JSON.stringify(obj))
// JSON 对象 属性和值有引号,而是引号统一是双引号
// {"uname":"pink老师","age":18,"gender":"女"}
// 取
// console.log(typeof localStorage.getItem('obj'))
// 2. 把JSON字符串转换为 对象
const str = localStorage.getItem('obj') // {"uname":"pink老师","age":18,"gender":"女"}
console.log(JSON.parse(str))
</script>
</body>
</html>
综合案例
data:image/s3,"s3://crabby-images/b729f/b729f6f5e730e6d50b8386caa555b0830b8b537a" alt=""
data:image/s3,"s3://crabby-images/07a75/07a75269050a9d1f09797395ef2c30d68246bebd" alt=""
data:image/s3,"s3://crabby-images/1ddc3/1ddc3d8e44159c4fedc0d9a056e0bfdb5d91bc3f" alt=""
data:image/s3,"s3://crabby-images/99d5f/99d5fb7705684c33a5a11ea094eb36cf2e1f4d3f" alt=""
data:image/s3,"s3://crabby-images/3edc0/3edc0f1c04f661bb97df8bfe8f59434d6a856b1e" alt=""
数组方法
map方法
data:image/s3,"s3://crabby-images/594c0/594c00030305f7234cf6ffbd213cb1c61cfb45ba" alt=""
data:image/s3,"s3://crabby-images/5c25a/5c25a0685e4841d95e1e5fc28b05db0c4fb455c4" alt=""
join方法
data:image/s3,"s3://crabby-images/8c4e0/8c4e094c06fc25182ec09762b616bc59412729b8" alt=""
data:image/s3,"s3://crabby-images/021cc/021cc597fbba8641bbe75a5241cffd93c7fbb3f5" alt=""
data:image/s3,"s3://crabby-images/f8fa7/f8fa72b7bfe38fa83794b970083524fcf5f8ed9e" alt=""
data:image/s3,"s3://crabby-images/ad8ab/ad8ab546b8b7cfce8cd1aa4f0ea2deca117f2026" alt=""
data:image/s3,"s3://crabby-images/09b04/09b04742f8eda229856dbd72bff15ec10d48b720" alt=""
data:image/s3,"s3://crabby-images/c4195/c41956cfc2fbca07348b3cc312730a1a8f1580e7" alt=""
data:image/s3,"s3://crabby-images/cd462/cd462ebe3a5089731ec6b0f744ff062e985edbbf" alt=""
data:image/s3,"s3://crabby-images/d972a/d972a02737fff79c278b252cf47591d57222e4fc" alt=""
data:image/s3,"s3://crabby-images/4c9fc/4c9fccb7649d19f03e3680638dae6fa4f053af8f" alt=""