首页 > 语言 > JavaScript > 正文

React组件的三种写法总结

2024-05-06 15:02:59
字体:
来源:转载
供稿:网友

React 专注于 view 层,组件化则是 React 的基础,也是其核心理念之一,一个完整的应用将由一个个独立的组件拼装而成。

截至目前 React 已经更新到 v15.4.2,由于 ES6 的普及和不同业务场景的影响,我们会发现目前主要有三种创建 React 组件的写法:1. ES5写法React.createClass,2. ES6写法React.Component,3. 无状态的函数式写法(纯组件-SFC)。

你们最钟爱哪种写法呢?萝卜青菜各有所爱~ 每个团队都有自己的代码规范和开发模式,但书写 React 组件时 都会以提高代码阅读性、更优的组件性能、易于 bug 追踪为原则。下面我们就聊聊这三种写法的区别,以及各自所适用场景的最佳实践。

ES5-写法 React.createClass

React.createClass不用多说,我们最早使用这个方法来构建一个组件“类”,它接受一个对象为参数,对象中必须声明一个render方法,render返回一个组件实例,下面用一个 SwitchButton 组件的例子来看看React.createClass的具体用法:

var React = require('react');var ReactDOM = require('react-dom');var SwitchButton = React.createClass({ getDefaultProp:function() { return { open: false } }, getInitialState: function() { return { open: this.props.open }; }, handleClick: function(event) { this.setState({ open: !this.state.open }); }, render: function() { var open = this.state.open,  className = open ? 'switch-button open' : 'btn-switch'; return (  <label className={className} onClick={this.handleClick.bind(this)}>  <input type="checkbox" checked={open}/>  </label> ); }});ReactDOM.render( <SwitchButton />, document.getElementById('app'));

ES6-写法 React.Component

React 升级到 v0.13 后就支持了 ES6 的class语法,我们可以使用class App extends React.Component{...}的方式创建组件,这也是目前官方推荐创建有状态组件的方式。用 ES6 重写上面 SwitchButton 组件的例子:

import React from 'react'import { render } from 'react-dom'class SwitchButton extends React.Component { constructor(props) { super(props) this.state = {  open: this.props.open } this.handleClick = this.handleClick.bind(this) } handleClick(event) { this.setState({ open: !this.state.open }) } render() { let open = this.state.open,  className = open ? 'switch-button open' : 'btn-switch' return (  <label className={className} onClick={this.handleClick}>  <input type="checkbox" checked={open}/>  </label> ) }}SwitchButton.defaultProps = { open: false}render( <SwitchButton />, document.getElementById('app'))

与React.createClass创建组件的不同之处:

import

与这里使用了 ES6 的import语句替代require()方法导入模块,其中import {render}可以直接从模块中导入变量名,这种写法更加简洁直观。

初始化 state

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选