React 專注于 view 層,組件化則是 React 的基礎(chǔ),也是其核心理念之一,一個完整的應(yīng)用將由一個個獨立的組件拼裝而成。
截至目前 React 已經(jīng)更新到 v15.4.2,由于 ES6 的普及和不同業(yè)務(wù)場景的影響,我們會發(fā)現(xiàn)目前主要有三種創(chuàng)建 React 組件的寫法:1. ES5寫法React.createClass,2. ES6寫法React.Component,3. 無狀態(tài)的函數(shù)式寫法(純組件-SFC)。
你們最鐘愛哪種寫法呢?蘿卜青菜各有所愛~ 每個團隊都有自己的代碼規(guī)范和開發(fā)模式,但書寫 React 組件時 都會以提高代碼閱讀性、更優(yōu)的組件性能、易于 bug 追蹤為原則。下面我們就聊聊這三種寫法的區(qū)別,以及各自所適用場景的最佳實踐。
ES5-寫法 React.createClass
React.createClass不用多說,我們最早使用這個方法來構(gòu)建一個組件“類”,它接受一個對象為參數(shù),對象中必須聲明一個render方法,render返回一個組件實例,下面用一個 SwitchButton 組件的例子來看看React.createClass的具體用法:
1 var React = require('react'); 2 var ReactDOM = require('react-dom'); 3 4 var SwitchButton = React.createClass({ 5 getDefaultProp:function() { 6 return { open:&nb