[React] Creating a Stateless Functional Component

Most of the components that you write will be stateless, meaning that they take in props and return what you want to be displayed. In React 0.14, a simpler syntax for writing these kinds of components was introduced, and we began calling these components "stateless functional components". In this lesson, let's take a look at how to define a stateless function component, and how to integrate useful React features like Prop Type validation while using this new component syntax.

 

Compnents with State:

复制代码
class Title extends React.Component {
  render(){
    return (
      <h1>{this.props.value}</h1>
    )
  }
}

class App extends React.Component {
  render(){
    return (
      <Title value="Hello World!" />
    )
  }
}

ReactDOM.render(
  <App />,
  document.querySelector("#root")
)
复制代码

 

Conver Title component to stateless component:

复制代码
const Title =  (props) => (
  <h1>{props.value}</h1>
)

class App extends React.Component {
  render(){
    return (
      <Title value="Hello World!" />
    )
  }
}

ReactDOM.render(
  <App />,
  document.querySelector("#root")
)
复制代码

So now you cannot access lifecycle hooks, anyway a dump compoennt doesn't need to handle those lifecycle hooks.

 

But if you want to set defaultProps and propTypes, it is still possible:

复制代码
/*class Title extends React.Component {
  render(){
    return (
      <h1>{this.props.value}</h1>
    )
  }
}
*/
const Title =  (props) => (
  <h1>{props.value}</h1>
)
Title.propTypes = {
  value: React.PropTypes.string.isRequired
}
Title.defaultProps = {
  value: "Egghead.io is Awson!!"
}

class App extends React.Component {
  render(){
    return (
      <Title value="Hello World!" />
    )
  }
}

ReactDOM.render(
  <App />,
  document.querySelector("#root")
)
复制代码

Statless compoennt rendering much fast than extends one.

posted @   Zhentiw  阅读(650)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示