赞
踩
一、React中的render()
1、render():是 class 组件中唯一必须实现的方法
2、当 render 被调用时,它会检查 this.props 和 this.state 的变化并返回以下类型之一:
(1)React 元素。通常通过 JSX 创建。例如,<div /> 会被 React 渲染为 DOM 节点,<MyComponent /> 会被 React 渲染为自定义组件,无论是 <div /> 还是 <MyComponent /> 均为 React 元素。
(2)数组或 fragments。 使得 render 方法可以返回多个元素。
(3)Portals。可以渲染子节点到不同的 DOM 子树中。
(4)字符串或数值类型。它们在 DOM 中会被渲染为文本节点
(5)布尔类型或 null。什么都不渲染。(主要用于支持返回 test && <Child /> 的模式,其中 test 为布尔类型。)
3、render() 函数应该为纯函数,这意味着在不修改组件 state 的情况下,每次调用时都返回相同的结果,并且它不会直接与浏览器交互。
4、如需与浏览器进行交互,请在 componentDidMount() 或其他生命周期方法中执行你的操作。保持 render() 为纯函数,可以使组件更容易使用、维护。
5、在React.Component类的子类中会重新定义(实现)
6、在react中,触发render的有4条路径。
以下假设shouldComponentUpdate都是按照默认返回true的方式。
(1)首次渲染Initial Render
(2)调用this.setState (并不是一次setState会触发一次render,React可能会合并操作,再一次性进行render)
(3)父组件发生更新(一般就是props发生改变,但是就算props没有改变或者父子组件之间没有数据交换也会触发render)
(4)调用this.forceUpdate
7、生命周期流程图(来源于官网)
注意:如果在shouldComponentUpdate里面返回false可以提前退出更新路径
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。