react的state和props

state狀態(tài)和props屬性是react非常重要的兩個(gè)方面,狀態(tài)控制組件內(nèi)部的變化,屬性獲取外部傳遞給內(nèi)部的數(shù)據(jù),當(dāng)state和props改變時(shí),會(huì)重新調(diào)用render方法,渲染dom對象。

state狀態(tài)

常用方法:

  1. getInitialState:獲取組件的初始化狀態(tài),在組件加載的時(shí)候調(diào)用(render前)
  2. this.state:獲取組件的狀態(tài)的值,但不能通過this.state.xxx = xxx改變狀態(tài)的值
  3. this.setState:用來改變組件狀態(tài)的值 ,用法如下
var Radio= React.createClass({ 
  // 定義組件的初始狀態(tài),初始為關(guān) 
  getInitialState: function() {
     return { checked: false } 
  }, // 通過 this.state 獲取當(dāng)前狀態(tài) 
  changeCheck: function() { 
    this.setState({ checked: !this.state.checked}); }
 }),
  render: function() {
     return <label className="radio"> 
        <input type="radio" checked={this.state.checked} onChange={this.changeCheck}/> 選中
      </label> 
},
 // 通過 setState 修改組件狀態(tài) // setState 過后會(huì) React 會(huì)調(diào)用 render 方法重渲染 

props屬性

常用方法:
1.this.props.xxx 用來獲取寫在組件中的xxx屬性的值 注意jsx中class屬性為 className,for屬性為 htmlFor;
2.getDefaultProps:獲取默認(rèn)的屬性對象,在render前調(diào)用一次,用于將組件中綁定的屬性添加到this.props ;可以設(shè)置默認(rèn)值,當(dāng)組件屬性沒傳值時(shí),調(diào)用默認(rèn)值;
3.this.props.children :獲取子節(jié)點(diǎn)的屬性,其中children只能為一個(gè)元素,不能為組件

var GetChildItem = React.createClass({ 
  render: function() { 
    var props = this.props; 
    return <div className="todo-item"> 
      <span class="todo-item__name">{props.children}</span> 
    </div> 
    }
 });
 ReactDOM.render( 
    <GetChildItem >子節(jié)點(diǎn)內(nèi)容</GetChildItem >, document.getElementById('example'));
  1. propsType用來校驗(yàn)屬性傳遞的正確性(非空,類型驗(yàn)證等),通常寫在最前面;
    var MyComponent = React.createClass({
        propTypes: {
            optionalRequired:React.PropTypes.isRequired,//不能為空
            optionalArray: React.PropTypes.array,
            optionalBool: React.PropTypes.bool,
            optionalFunc: React.PropTypes.func,
            optionalNumber: React.PropTypes.number,
            optionalObject: React.PropTypes.object,
            optionalString: React.PropTypes.string,
            // 任何可以被渲染的包括,數(shù)字,字符串,組件,或者數(shù)組
            optionalNode: React.PropTypes.node,
            // React 元素
            optionalElement: React.PropTypes.element,
            customProp: function(props, propName, componentName) {}//自定義校驗(yàn)
        }
    });
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 原教程內(nèi)容詳見精益 React 學(xué)習(xí)指南,這只是我在學(xué)習(xí)過程中的一些閱讀筆記,個(gè)人覺得該教程講解深入淺出,比目前大...
    leonaxiong閱讀 2,944評論 1 18
  • 目前,react組件有三種寫法,分別是es5的createClass寫法,es6的class寫法,以及statel...
    ZoomFunc閱讀 1,911評論 0 1
  • React Native是基于React的,在開發(fā)React Native過程中少不了的需要用到React方面的知...
    亓凡閱讀 1,578評論 1 4
  • 現(xiàn)在最熱門的前端框架,毫無疑問是 React 。上周,基于 React 的 React Native 發(fā)布,結(jié)果一...
    sakura_L閱讀 488評論 0 0
  • GUIDS 第一章 為什么使用React? React 一個(gè)提供了用戶接口的JavaScript庫。 誕生于Fac...
    jplyue閱讀 3,710評論 1 11

友情鏈接更多精彩內(nèi)容