js:
特性:js是弱类型(动态类型)语言,在声明变量时无需指定类型且在运行时可赋值为任意类型;不自带样式,不会直接影响页面的样式、布局、排版;
js功能强大,能做很多事情:操作页面,操作浏览器;计算,逻辑,数据处理,读写文件;发网络请求;写后端服务(Node.js);移动端app;嵌入式;游戏开发,脚本自动化等等
1.js操作页面与浏览器: DOM和BOM的根都是window对象
1.1.DOM:文档对象模型(Document Object Model),浏览器把html转化成js能看懂的"对象树"dom;js通过dom提供的api操作网页内容(HTML 里的 div、文字、样式)
BOM:浏览器对象模型(Browser Object Model),操作浏览器窗口(跳转、刷新、地址栏、弹窗、历史、存储);原理同上
DOM常见操作:
找元素:querySelector、getElementById
改内容:innerHTML、textContent
改样式:style.color、style.width
改属性:src、href、class
加事件:onclick、addEventListener
增删元素:createElement、appendChild、remove
例子:
document.querySelector('.box').style.width = '500px';//找到页面上class="box"的元素,把它的宽度改成500px
document.body.innerHTML = '<div>新内容</div>'; //把网页body里原来的所有内容清空替换成新的HTML结构
1.2.BOM常见操作:
弹窗相关:
alert('提示')
confirm('确定吗?')
prompt('输入内容')
页面跳转,刷新:
// 跳转到别的页面
location.href = 'https://www.baidu.com'
// 刷新页面
location.reload() //location就是bom对象
浏览器历史:
history.back() // 返回上一页
history.forward() // 前进一页
定时器:
setTimeout(() => {}, 1000)
setInterval(() => {}, 1000)
窗口大小,滚动:
window.innerWidth // 窗口宽度
window.scrollY // 滚动距离
window.scrollTo(0, 0) // 滚到顶部
本地存储:
localStorage.setItem('name', '张三')
sessionStorage
location、setTimeout、localStorage、alert、history都属于bom提供的对象
2.网络请求:
发展历史:
| 方案 | 本质 | 出现时间 | 地位 |
|---|---|---|---|
| XMLHttpRequest(XHR) | AJAX 原生底层 | 1999 | 祖师爷 |
| jQuery.ajax | 封装 XHR | 2006 | 曾经的王者 |
| fetch | 浏览器原生新 API | 2015 | 原生替代方案 |
| axios | 封装 XHR + Promise | 2016 | 现在行业标准 |
现在用的最多的就是axios,一个专门用于http网络请求的js库,基于XMLHttpRequest,Promise风格:统一用 .then() / .catch(),链式清晰
4xx/5xx 自动 reject
支持请求 / 响应拦截器
支持取消请求、超时、上传进度
随着Vue、React流行,axios彻底取代jQuery.ajax
常见的js库:jQuery,axios,lodash,moment/dayjs,vue,react
jQuery:是一个非常经典,老牌的js库,用更少代码,更方便地操作DOM和做AJAX请求;
主要解决两大痛点:抹平浏览器差异;简化DOM操作、事件、动画、AJAX请求;后来 Vue、React 出现,大家不再大量操作 DOM,jQuery 就慢慢退出主流
lodash:标准实用的js工具类库,更轻松地处理数组、对象、字符串等常见数据结构,进行深拷贝,数组去重,防抖节流,安全取值,遍历、过滤、分组等操作