当前位置: 首页 > news >正文

万网网站备案查询wordpress.zip

万网网站备案查询,wordpress.zip,江西seo推广软件,p2p网站建设的步骤过程1. 前言 本篇梳理和总结一下React的生命周期函数,方便使用class组件的同学查阅,先上生命周期图谱。 2. 生命周期函数 生命周期函数说明constructor(props) 功能:如果不需要初始化state或不进行方法绑定,class组件可以不用实现构造…
1. 前言

        本篇梳理和总结一下React的生命周期函数,方便使用class组件的同学查阅,先上生命周期图谱。

2. 生命周期函数
生命周期函数说明
constructor(props)

功能:如果不需要初始化state或不进行方法绑定,class组件可以不用实现构造函数constructor。

输入:props - 设置组件当前状态props

static getDerivedStateFromProps(

    nextProps,

    state

)

功能:静态方法,在调用render方法之前调用,挂载或更新时都会调用,返回一个新对象来更新state。

注:即用新props来更新state

输入

nextProps - 还未更新的接下来props

state - 组件当前状态

输出:state -组件新的状态

shouldComponentUpdate(

    nextProps,

    nextState

)

功能:根据该函数返回时,判断React组件输出是否受当前state或props更改的影响,默认行为是state每次发生变化组件都会重新渲染

注:首次渲染或forceUpdate时不用调用该方法

输入

nextProps - 还未更新的接下来props

nextState - 还未更新的接下来state

输出:boolean(返回false,则跳过更新)

render()

功能:检查this.props和this.state变化,是纯函数。

注:shouldComponentUpdate返回false,则不调用render

输入:无

输出:ReactElement | 数组或Fragments | Portals | string | number | boolean | null | undefined

getSnapshotBeforeUpdate(

    prevProps,

    prevState

)

功能:最近一次渲染输出(提交到DOM节点)之前调用,返回值传递给componentDidUpdate第3个参数,此处适合的操作:

1. 在发生更改前从DOM中捕获一些信息(滚动位置)

输入

prevProps - 在更新之前的props

prevState - 在更新之前的state

输出:snapShot

componentDidUpdate(

    prevProps,

    prevState,

    snapShot

)

功能:组件更新后立即调用,首次渲染不执行,适合在此处的操作:

1. 比较前后props发起网络请求

2. DOM操作

注:可以在此处调用setState,但需要包裹在条件语句中,防止死循环

输入

prevProps - 在更新之前的props

prevState - 在更新之前的state

snapShot -getSnapshotBeforeUpdate返回的快照

componentDidMount()

功能:组件挂载(插入DOM树)后立即调用,适合在此处的操作:

1. 设置定时器timer

2. 发起网络请求

3. 添加订阅

4. DOM操作

注:可以在此处调用setState,但会导致性能问题

输入:无

componentWillUnmount()

功能:class组件卸载及销毁之前直接调用,执行必要清理工作:

1. 清除tImer

2. 取消网络请求

3. 清除订阅

注:不能在此处调用setState

输入:无

异常出错时的生命周期函数
static getDerivedStateFromError(error)

功能:当后代组件抛出错误后被调用

注:该函数在渲染阶段调用,不允许出现副作用。

输入:error - 抛出的错误

输出:state -组件新的状态

componentDidCatch(error, info)

功能:当后代组件抛出错误后被调用

注:该函数在提交阶段调用,允许执行副作用。开发模式错误会冒泡到window,生产模式不会冒泡。

输入

error - 抛出的错误

info - 带有componentStack key的对象,包含组件引发错误的栈信息

2.1 挂载

        当组件实例被创建并插件DOM时,其生命周期函数调用顺序如下:

  • constructor(props)
  • static getDerivedStateFromProps()
  • render()
  • componentDidMount()
2.2 更新

        当组件更新时,其生命周期函数调用顺序如下:

  • new props、setState和forceUpdate触发更新
  • static getDerivedStateFromProps()
  • shouldComponentUpdate()
  • render()
  • getSnapshotBeforeUpdate()
  • componentDidUpate()
2.3 卸载
  • componentWillUnmount()
3. 总结

        学习或复习时,注意各生命周期方法的参数,部分带参数的方法,props在前,state在后,render之前的是nextProps nextState(渲染阶段),render之后的是prevProps, prevState(提交阶段)。

        React新的官方文档已再不提生命周期函数,将PureComponent和Component标记为过时的API,笔者猜想React后续不再推荐使用class组件,而是转入函数组件FC,欢迎大家进入Hook的世界。

下一篇:【React】常用Hook函数的梳理和总结(第二篇)-CSDN博客

注:以上,如有不合理之处,还请帮忙指出,大家一起交流学习~  

http://www.yayakq.cn/news/158467/

相关文章:

  • 什么网站可以做图片360建筑网怎么注销账号
  • 网站添加标签云网站开发播放大视频卡顿
  • 网站制作常见问题网页设计的五大原则
  • 网站改版不更换域名 .net怎么做301网站重定向网站后台发了文章看不到
  • 网站建设和管理制度摄影网站开题报告
  • 男女一起做暖暖网站创建网站要多少钱
  • 免费logo网站html解析wordpress
  • 我市精神文明建设的门户网站是网站推广怎么优化
  • 网站开发如何无感更新学做衣服上什么网站
  • 如何快速备案网站吉林省建设厅网站市政资质要求
  • 网站备案 拨测手机网站自助建站源码
  • dede网站logo怎么改服装店的营销方法
  • 买房网站怎么做网站维护中页面代码
  • 购物网站开发目的参考消息
  • 忘记wordpress福州seo服务商
  • 网站推荐免费的wordpress更新服务评论
  • 网站形式的设计制作高端app开发公司
  • 有哪些网站建设公司市体育局网站 两学一做
  • 北京律师网站建设平台u盘搭建网站开发环境方法
  • 网站备案 上线怎么生成网站源代码
  • 做包装的网站seo从0到1怎么做
  • 小公司怎么做免费网站太原seo整站优化
  • 网站建设能否建立国外站免费推广的平台
  • 找回网站备案密码搜索网页内容
  • 学校网站建设方案书wordpress上传附件类型
  • 如何查网站开发商怎样更新网站内容
  • 微信怎么建小网站app软件开发外包公司
  • 运维 网站开发网站内容如何自动关联新浪微博
  • 医疗网站项目策划ppt可以做网站吗
  • 湖南响应式网站建设推荐找晚上做的工作去哪个网站