js总结介绍

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工具类库,更轻松地处理数组、对象、字符串等常见数据结构,进行深拷贝,数组去重,防抖节流,安全取值,遍历、过滤、分组等操作

相关推荐
纯爱掌门人2 小时前
干了这么多年前端,聊聊 2026 年我们到底还值不值钱
前端·程序员
houhou2 小时前
Monaco Editor 集成指南:从配置到优化
前端
hunterandroid2 小时前
[Android 从零到一] Custom View 自定义绘制:从 onDraw 到完整交互
前端
李明卫杭州2 小时前
Vue3 v-memo 指令详解:让你的列表渲染性能翻倍 🚀
前端
梨子同志2 小时前
Monorepo
前端
lihaozecq2 小时前
继 Web Coding Agent 后,我做了一个本地优先的桌面 AI Agent
前端·agent
用户298698530143 小时前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
CodingSpace3 小时前
ESLint
前端
Csvn3 小时前
异步错误捕获的六大陷阱:await 裹着 try-catch 就一定稳了吗?
前端
用户059540174463 小时前
向量库静默丢数据踩坑实录:Playwright 端到端测试让我排查了72小时
前端·css