搭建网站是要什么,做网站要切图吗,广告设计与制作专业认识,wordpress导航页面模板下载地址好程序员web前端培训分享React学习笔记(三)#xff0c;组件的生命周期React中组件也有生命周期#xff0c;也就是说也有很多钩子函数供我们使用, 组件的生命周期#xff0c;我们会分为四个阶段#xff0c;初始化、运行中、销毁、错误处理(16.3之后)初始化在组件初始化阶段会… 好程序员web前端培训分享React学习笔记(三)组件的生命周期 React中组件也有生命周期也就是说也有很多钩子函数供我们使用, 组件的生命周期我们会分为四个阶段初始化、运行中、销毁、错误处理(16.3之后)初始化在组件初始化阶段会执行00001. constructor00002. static getDerivedStateFromProps()00003. componentWillMount() / UNSAFE_componentWillMount()00004. render()00005. componentDidMount()更新阶段props或state的改变可能会引起组件的更新组件重新渲染的过程中会调用以下方法00001. componentWillReceiveProps() / UNSAFE_componentWillReceiveProps()00002. static getDerivedStateFromProps()00003. shouldComponentUpdate()00004. componentWillUpdate() / UNSAFE_componentWillUpdate()00005. render()00006. getSnapshotBeforeUpdate()00007. componentDidUpdate()卸载阶段00001. componentWillUnmount()错误处理00001. componentDidCatch()各生命周期详解1.constructor(props)React组件的构造函数在挂载之前被调用。在实现React.Component构造函数时需要先在添加其他内容前调用super(props)用来将父组件传来的props绑定到这个类中使用this.props将会得到。官方建议不要在constructor引入任何具有副作用和订阅功能的代码这些应当使用componentDidMount()。constructor中应当做些初始化的动作如初始化state将事件处理函数绑定到类实例上但也不要使用setState()。如果没有必要初始化state或绑定方法则不需要构造constructor或者把这个组件换成纯函数写法。当然也可以利用props初始化state在之后修改state不会对props造成任何修改但仍然建议大家提升状态到父组件中或使用redux统一进行状态管理。constructor(props) { super(props); this.state { isLiked: props.isLiked };}2.static getDerivedStateFromProps(nextProps, prevState)getDerivedStateFromProps 是react16.3之后新增在组件实例化后和接受新的props后被调用。他必须返回一个对象来更新状态或者返回null表示新的props不需要任何state的更新。如果是由于父组件的props更改所带来的重新渲染也会触发此方法。调用steState()不会触发getDerivedStateFromProps()。之前这里都是使用constructorcomponentWillRecieveProps完成相同的功能的3. componentWillMount() / UNSAFE_componentWillMount()componentWillMount()将在React未来版本(官方说法 17.0)中被弃用。UNSAFE_componentWillMount()在组件挂载前被调用在这个方法中调用setState()不会起作用是由于他在render()前被调用。为了避免副作用和其他的订阅官方都建议使用componentDidMount()代替。这个方法是用于在服务器渲染上的唯一方法。这个方法因为是在渲染之前被调用也是惟一一个可以直接同步修改state的地方。4.render()render()方法是必需的。当他被调用时他将计算this.props和this.state并返回以下一种类型00001. React元素。通过jsx创建既可以是dom元素也可以是用户自定义的组件。00002. 字符串或数字。他们将会以文本节点形式渲染到dom中。00003. Portals。react 16版本中提出的新的解决方案可以使组件脱离父组件层级直接挂载在DOM树的任何位置。00004. null什么也不渲染00005. 布尔值。也是什么都不渲染。当返回null,false,ReactDOM.findDOMNode(this)将会返回null什么都不会渲染。render()方法必须是一个纯函数他不应该改变state也不能直接和浏览器进行交互应该将事件放在其他生命周期函数中。 如果shouldComponentUpdate()返回falserender()不会被调用。5. componentDidMountcomponentDidMount在组件被装配后立即调用。初始化使得DOM节点应该进行到这里。通常在这里进行ajax请求如果要初始化第三方的dom库也在这里进行初始化。只有到这里才能获取到真实的dom.6.componentWillReceiveProps()/UNSAFE_componentWillReceiveProps(nextProps)官方建议使用getDerivedStateFromProps函数代替componentWillReceiveProps。当组件挂载后接收到新的props后会被调用。如果需要更新state来响应props的更改则可以进行this.props和nextProps的比较并在此方法中使用this.setState()。如果父组件会让这个组件重新渲染即使props没有改变也会调用这个方法。React不会在组件初始化props时调用这个方法。调用this.setState也不会触发。7.shouldComponentUpdate(nextProps, nextState)调用shouldComponentUpdate使React知道组件的输出是否受state和props的影响。默认每个状态的更改都会重新渲染大多数情况下应该保持这个默认行为。在渲染新的props或state前shouldComponentUpdate会被调用。默认为true。这个方法不会在初始化时被调用也不会在forceUpdate()时被调用。返回false不会阻止子组件在state更改时重新渲染。如果shouldComponentUpdate()返回falsecomponentWillUpdate,render和componentDidUpdate不会被调用。官方并不建议在shouldComponentUpdate()中进行深度查询或使用JSON.stringify()他效率非常低并且损伤性能。8.UNSAFE_componentWillUpdate(nextProps, nextState)在渲染新的state或props时UNSAFE_componentWillUpdate会被调用将此作为在更新发生之前进行准备的机会。这个方法不会在初始化时被调用。不能在这里使用this.setState()也不能做会触发视图更新的操作。如果需要更新state或props调用getDerivedStateFromProps。9.getSnapshotBeforeUpdate()在react render()后的输出被渲染到DOM之前被调用。它使您的组件能够在它们被潜在更改之前捕获当前值(如滚动位置)。这个生命周期返回的任何值都将作为参数传递给componentDidUpdate()。10.componentDidUpdate(prevProps, prevState, snapshot)在更新发生后立即调用componentDidUpdate()。此方法不用于初始渲染。当组件更新时将此作为一个机会来操作DOM。只要您将当前的props与以前的props进行比较(例如如果props没有改变则可能不需要网络请求)这也是做网络请求的好地方。如果组件实现getSnapshotBeforeUpdate()生命周期则它返回的值将作为第三个“快照”参数传递给componentDidUpdate()。否则这个参数是undefined。11.componentWillUnmount()在组件被卸载并销毁之前立即被调用。在此方法中执行任何必要的清理例如使定时器无效取消网络请求或清理在componentDidMount中创建的任何监听。12.componentDidCatch(error, info)错误边界是React组件可以在其子组件树中的任何位置捕获JavaScript错误记录这些错误并显示回退UI而不是崩溃的组件树。错误边界在渲染期间生命周期方法以及整个树下的构造函数中捕获错误。如果类组件定义了此生命周期方法则它将成错误边界。在它中调用setState()可以让你在下面的树中捕获未处理的JavaScript错误并显示一个后备UI。只能使用错误边界从意外异常中恢复; 不要试图将它们用于控制流程。错误边界只会捕获树中下面组件中的错误。错误边界本身不能捕获错误。PureComponentPureComponnet里如果接收到的新属性或者是更改后的状态和原属性、原状态相同的话就不会去重新render了 在里面也可以使用shouldComponentUpdate而且。是否重新渲染以shouldComponentUpdate的返回值为最终的决定因素。import React, { PureComponent } from reactclass YourComponent extends PureComponent { ……}refReact提供的这个ref属性表示为对组件真正实例的引用其实就是ReactDOM.render()返回的组件实例,ref可以挂载到组件上也可以是dom元素上。· 挂到组件(class声明的组件)上的ref表示对组件实例的引用。不能在函数式组件上使用 ref 属性因为它们没有实例· 挂载到dom元素上时表示具体的dom元素节点。在React 最新的版本中要使用ref, 需要使用React.createRef方法先生成一个ref。import React, { Component, createRef } from reactimport ReactDOM from react-domclass App extends Component { constructor() { super() // 创建inputRef this.inputRefcreateRef() } componentDidMount () { console.log(this.inputRef.current) // } render () { return ( div {/* 关联ref和dom */} input typetext ref{this.inputRef} / /div ) }}ReactDOM.render( App/, document.getElementById(root))React HooksReact Hooks 是 React 16.7.0-alpha 版本推出的新特性, 有了React Hooks在 react 函数组件中也可以使用类组件(classes components)的 state 和 组件生命周期。通过下面几个例子来学习React Hooks。· State Hook// useState是react包提供的一个方法import React, { useState } from react;import ReactDOM from react-dom;const Counter () { // useState 这个方法可以为我们的函数组件拥有自己的state它接收一个用于初始 state 的值返回一对变量。这里我们把计数器的初始值设置为0, 方法都是以set开始 const [count, setCount] useState(0); return ( div p你点击了{count}次/p button onClick{() setCount(count 1)}点击/button /div );};const rootElement document.getElementById(root);ReactDOM.render(Counter /, rootElement);· Effect Hook// useState是react包提供的一个方法import React, { useState, useEffect } from react;import ReactDOM from react-dom;const Counter () { // useState 这个方法可以为我们的函数组件拥有自己的state它接收一个用于初始 state 的值返回一对变量。这里我们把计数器的初始值设置为0, 方法都是以set开始 const [count, setCount] useState(0); // 类似于componentDidMount或者componentDidUpdate: useEffect(() { // 更改网页的标题还可以做其它的监听 document.title 你点击了${count}次; }); return ( div p你点击了{count}次/p button onClick{() setCount(count 1)}点击/button /div );};const rootElement document.getElementById(root);ReactDOM.render(Counter /, rootElement);· React Hooks 的规则· 只能在顶层调用Hooks。不要在循环条件或嵌套函数中调用Hook。· 不要从常规JavaScript函数中调用Hook。只在React函数式组件调用Hooks。· 自定义hooks可以选择讲解· react 内置hooks api· Basic Hooks· useState· useEffect· useContext· Additional Hooks· useReducer· useCallback· useMemo· useRef· useImperativeHandle· useLayoutEffect· useDebugValue