参考答案:
1class Welcome extends React.Component { 2 render() { 3 return ( 4 <h1>Welcome { this.props.name }</h1> 5 ); 6 } 7} 8ReactDOM.render(<Welcome name='react' />, document.getElementById('root'));
函数组件接收一个单一的 props 对象并返回了一个React元素
1function Welcome (props) { 2 return <h1>Welcome {props.name}</h1> 3} 4ReactDOM.render(<Welcome name='react' />, document.getElementById('root'));
两者最明显的不同就是在语法上,函数组件是一个纯函数,它接收一个props对象返回一个react元素。而类组件需要去继承React.Component并且创建render函数返回react元素,这将会要更多的代码,虽然它们实现的效果相同。
因为函数组件是一个纯函数,你不能在组件中使用setState(),这也是为什么把函数组件称作为无状态组件。
如果你需要在你的组件中使用state,你可以选择创建一个类组件或者将state提升到你的父组件中,然后通过props对象传递到子组件。
你不能在函数组件中使用生命周期钩子,原因和不能使用state一样,所有的生命周期钩子都来自于继承的React.Component中。
因此,如果你想使用生命周期钩子,那么需要使用类组件。
注意:在react16.8版本中添加了hooks,使得我们可以在函数组件中使用useState钩子去管理state,使用useEffect钩子去使用生命周期函数。因此,2、3两点就不是它们的区别点。从这个改版中我们可以看出作者更加看重函数组件,而且react团队曾提及到在react之后的版本将会对函数组件的性能方面进行提升。
如果SayHi是一个函数,React需要调用它:
1// 你的代码 2function SayHi() { 3 return <p>Hello, React</p> 4} 5// React内部 6const result = SayHi(props) // » <p>Hello, React</p>
如果SayHi是一个类,React需要先用new操作符将其实例化,然后调用刚才生成实例的render方法:
1// 你的代码 2class SayHi extends React.Component { 3 render() { 4 return <p>Hello, React</p> 5 } 6} 7// React内部 8const instance = new SayHi(props) // » SayHi {} 9const result = instance.render() // » <p>Hello, React</p>
可想而知,函数组件重新渲染将重新调用组件方法返回新的react元素,类组件重新渲染将new一个新的组件实例,然后调用render类方法返回react元素,这也说明为什么类组件中this是可变的。
最近更新时间:2024-08-10