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

相关推荐
Python大数据分析@2 小时前
HTML会代替Markdown吗?为什么?
前端·html
jiayong232 小时前
前端面试题库 - 工程化与性能优化篇
前端·面试·性能优化
暗冰ཏོ2 小时前
2026前端开发资源大全:工具、文档、框架、学习路线与实战指南
前端·前端开发工具·前端编程工具·前端资源·前端开发文档
踩着两条虫2 小时前
AI 低代码引擎可视化设计器交互机制实战
前端·vue.js·人工智能·低代码·架构
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_2:(连接样式表与选择器的实战艺术)
java·前端·css·ui·html·媒体
lichenyang4532 小时前
鸿蒙聊天 Demo 练习 01:发送消息、模拟 AI 回复与自动滚动
前端
白菜__2 小时前
微信小程序网关逆向分析
javascript·微信小程序·小程序·node.js·网络爬虫·微信网关·小程序网关
放下华子我只抽RuiKe52 小时前
React 从入门到生产(三):副作用与数据获取
前端·javascript·深度学习·react.js·开源·ecmascript·集成学习
微祎_2 小时前
写给前端的 CANN-ops-transformer:昇腾Transformer进阶算子库到底是啥?
前端·深度学习·transformer