IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react第一课 -> 正文阅读

[JavaScript知识库]react第一课

1。setState的一些想法

除了我们常见的写法外,setState的参数还可以是一个方法

`this.setState(()=>{
            return {
              count: count + 1
            }
          },()=>{
            console.log("组件更新完毕调用");
          })`

setState,有时候是一个同步的方法,有时候是一个异步的方法
在触发了批量更新机制的时候,setState是一个异步的方法,其他的时候setState是一个异步的方法

2。批量更新

在同一个操作中,多次调用 setState ,正常情况下 React 会将这些 setState 中的更新进行合并,只执行一次更新

 `<button onClick={()=>{
          this.setState({
            nub: nub+5
          });
          console.log(this.state.nub);
          this.setState({
            nub: nub+5
          });
          console.log(this.state.nub);
          this.setState({
            nub: nub+5
          });
          console.log(this.state.nub);
      }}>nub 递增</button>`
  例如上面这个代码,初始值nub是5,打印 出来是5,5,5,然后调用了一次render,这就是所说的批量更新

3。 react生命周期回顾

****挂载阶段(mount)- 从组件初始化到生成真实DOM节点并挂载真实DOM树中


  • constructor(props) 组件初始化
  • static getDerivedStateFromProps(props,state) 将 props 中内容关联到 state 中
  • render 构建当前组件的虚拟DOM
  • componentDidMount 组件挂载完成 - 通常在该生命周期函数,进行副作用处理

副作用处理:

  1. 异步请求
  2. DOM 获取

****更新阶段(update)- 从组件开始更新到修改完成真实的DOM节点


  • static getDerivedStateFromProps(props, state)
  • shouldComponentUpdate(nextProps,nextState) – 判断是否更新
    return true 组件更新 || false 不在继续执行更新流程
  • render()
  • getSnapshotBeforeUpdate(prevProps,prevState) – 获取更新前的DOM快照,该函数执行时react已经完成了新老DOM对比,即将更新真实DOM,我们可以获取更新前的DOM,用于和更新后的DOM进行对比。该方法必须配合 componentDidUpdate 一块使用,该方法的返回值,会变成 componentDidUpdate 的 pervDOM 参数
  • componentDidUpdate(prevProps,prevState,pervDOM) – 组件更新完成 处理副作用(请求)

****卸载阶段(unmount)


  • 从组件准备卸载,到将组件从真实DOM中删除:

4。组件在什么情况下会更新:

  1. 调用 setState 引起当前组件进行更新
  2. 父组件更新,会引起子组件进行更新
  3. 调用 forceUpdate 方法强制组件进行更新
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-26 11:59:24  更:2021-07-26 12:00:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:05:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码