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

相关推荐
lichenyang4531 分钟前
聊天历史从 Preferences 搬到关系型数据库(RDB):为什么换、怎么换、踩了什么坑
前端
HjhIron7 分钟前
从栈到队列,再到链表:前端开发者必知的线性数据结构
前端·javascript
PedroQue997 分钟前
uni-app路由管理神器:vue-router风格体验
前端·uni-app
用户1733598075378 分钟前
花两周用 Vue 3 做了个 PDF 工具站,我在生产环境踩了 8 个坑
前端·vue.js
风骏时光牛马8 分钟前
TypeScript 泛型与工具类型实战:企业级通用数据请求封装完整案例
前端
阿猫的故乡9 分钟前
Vue自定义指令从入门到实用:自动聚焦、权限控制、防抖、懒加载……全案例教学
前端·javascript·vue.js
嘟嘟071712 分钟前
吃透 JS 八大数据类型与内存原理,从代码到底层一站式复习
前端
问心无愧051313 分钟前
ctf show web入门157 158
前端·笔记
该用户已成仙26 分钟前
vue3 使用 vuedraggable 报错 TypeError: isFunction2 is not a function
前端·javascript·vue.js
aidou131426 分钟前
Kotlin中实现星级评价选择功能(仅支持整数)
前端·kotlin·自定义view·imageview·ontouchevent·customratingbar