欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React實(shí)現(xiàn)雙向綁定示例代碼

 更新時(shí)間:2016年09月19日 09:29:54   作者:starwmx520  
這篇文章給大家介紹了在React中如何實(shí)現(xiàn)雙向綁定,文中給出了示例代碼,對(duì)大家的理解與學(xué)習(xí)很有幫助,有需要的朋友下面來一起看看吧。

前言

React.js現(xiàn)在已經(jīng)很流行了,不會(huì)React.js都不好意思說自己會(huì)前端了。

那么下面就來看看關(guān)于React雙向綁定的實(shí)現(xiàn)。

雙向綁定的使用:

組件需要mixins:引用LinkedStateMixin。它提供一個(gè)linkState方法。

參數(shù)是state屬性

雙向綁定用valueLink={this.linkState(XX)}

linkState方法返回一個(gè)對(duì)象,有一個(gè)value屬性,指定state的屬性。

還有一個(gè)requestChange回調(diào)方法,用來實(shí)現(xiàn)state的修改。參數(shù)是新值

可以理解成onchange的綁定方法??梢宰约簩懸粋€(gè)linkState對(duì)象,value是state.XX requestChange里用setState()來修改值。用valueLink={obj}來實(shí)現(xiàn)。

可以理解成this.linkState()實(shí)現(xiàn)的就是指定綁定值value 和change方法

valueLink屬性實(shí)現(xiàn)了linkstate.value綁定到value requestChange方法綁定onChange

可以創(chuàng)建一個(gè)this.linkState('XX') value={XX.value} onchange={fn}方法內(nèi)使用Xx.requestChange(e.target.value)

-------------------------

小結(jié):linkState()方法提供state屬性和change方法。valueLink={}來實(shí)現(xiàn)value 和change事件的綁定。

以下是實(shí)現(xiàn)代碼

/*默認(rèn)表單雙向綁定
   * 給每個(gè)input綁定change事件來實(shí)現(xiàn)修改state
   * 如果標(biāo)簽多了一個(gè)個(gè)綁定肯定是不行的,
   * 所以react 給我個(gè)提示了reactLink來
   */
   var Box1=React.createClass({
   getInitialState:function(){
    return {
    name:'star',bool:true
    }
   },
   handlNameChange:function(event){
    this.setState({name:event.target.value});
   },handlboolChange:function(event){
    this.setState({bool:event.target.checked})
   },
   render:function(){
    return (
    <div>
     <input type="text" value={this.state.name} onChange={this.handlNameChange}/>   <br/>
     <input type="checkbox" checked={this.state.bool} onChange={this.handlboolChange} />
    </div> 
    )
   }
   }) ;
   React.render(<Box1></Box1>,document.querySelector('#div1'));
   
   /*ReactLink僅是提供了onchange setState模式的簡(jiǎn)單包裝和約定。是其的簡(jiǎn)寫方式
   * 1、需要mixins添加引用
   * 2、原先的value綁定換成valueLink。參數(shù)從this.state.XX換成this.linkState('XX')這樣就可以了
   */
   /*ReactLink解析
   * LinkedStateMixin給組件添加一個(gè)linkState方法,參數(shù)是state屬性名。
   * 它返回一個(gè)reactlink對(duì)象,包含state當(dāng)前值和一個(gè)改變值 的回調(diào).
   * reactlink 可以在組件間通過props傳遞
   */
   var Box2=React.createClass({
   mixins:[React.addons.LinkedStateMixin],//添加引用
   getInitialState:function(){
    return {
    name:'star',bool:true
    }
   },
   render:function(){//綁定時(shí)屬性從value換成valueLink值需要用this.linkState方法調(diào)用
    return (
    <div>
     <input type="text" valueLink={this.linkState('name')} />   <br/>
     <input type="checkbox" checkedLink={this.linkState('bool')} />
    </div>   
    );
   }
   })
   React.render(<Box2></Box2>,document.querySelector('#div2'));
   
   /*底層原理
   * reactlink對(duì)象其實(shí)就一個(gè)value屬性,和一個(gè)requestChange方法,value值 是state。方法實(shí)現(xiàn)修改state值
   * 
   */
   var Box3=React.createClass({
   getInitialState:function(){
    return {
    name:'star',bool:true
    }
   },
   handlnamechange:function(val){
    this.setState({name:val})
   },
   handlboolchange:function(val){
    this.setState({bool:val})
   },
   render:function(){
    var reactlink={
    value:this.state.name,
    requestChange:this.handlnamechange
    }
    var reactlink2={
    value:this.state.bool,
    requestChange:this.handlboolchange
    }
     return(
      <div>
     <input type="text" valueLink={reactlink} />   <br/>
     <input type="checkbox" checkedLink={reactlink2} />
    </div> 
     )
   }
   });
   React.render(<Box3></Box3>,document.querySelector('#div3'));
   
   /*valuelink
   * 它實(shí)際上實(shí)現(xiàn)的是狀態(tài)的綁定和change事件的修改
   * requestChange方法接收值來實(shí)現(xiàn)state的修改
   */
   var Box4=React.createClass({
   mixins:[React.addons.LinkedStateMixin],//添加引用
   getInitialState:function(){
    return {
    name:'star',bool:true
    }
   },
   render:function(){
    var valuelink=this.linkState('name');
    var handlenamechange=function(e){
      valuelink.requestChange(e.target.value) 
    }
    var valuelink2=this.linkState('bool');
    var handlenboolchange=function(e){
      valuelink2.requestChange(e.target.checked) 
    }    
    return (
      <div>
     <input type="text" value={valuelink.value} onChange={handlenamechange} />   <br/>
     <input type="checkbox" checked={valuelink2.value} onChange={handlenboolchange} />
    </div> 
    )
   }
   });
   React.render(<Box4></Box4>,document.querySelector('#div4'));

------------------------ReactLink對(duì)象傳遞

可以向子組件傳遞:

linkname={this.linkState('name')}

子組件內(nèi)可:

<input type="text" valueLink={this.props.linkname} >

通過props來引用并綁定到valueLink上。

也可以用this.props.linkname.requestChange()來用方法修改值 。

它們的變化 會(huì)同步到父組件的。并更新標(biāo)簽的。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能有所幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • 詳解react、redux、react-redux之間的關(guān)系

    詳解react、redux、react-redux之間的關(guān)系

    這篇文章主要介紹了詳解react、redux、react-redux之間的關(guān)系,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • React項(xiàng)目中使用Redux的?react-redux

    React項(xiàng)目中使用Redux的?react-redux

    這篇文章主要介紹了React項(xiàng)目中使用Redux的?react-redux,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • React聲明組件的方法總結(jié)

    React聲明組件的方法總結(jié)

    這篇文章主要給大家介紹了react聲明組件有哪幾種方法,各有什么不同,文章通過代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-11-11
  • antd?3.x?Table組件如何快速實(shí)現(xiàn)虛擬列表詳析

    antd?3.x?Table組件如何快速實(shí)現(xiàn)虛擬列表詳析

    這篇文章主要給大家介紹了關(guān)于antd?3.x?Table組件如何快速實(shí)現(xiàn)虛擬列表的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用antd具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-11-11
  • React Native中WebView與html雙向通信遇到的坑

    React Native中WebView與html雙向通信遇到的坑

    這篇文章主要介紹了React Native中WebView與html雙向通信的一些問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-01-01
  • React中super()和super(props)的區(qū)別小結(jié)

    React中super()和super(props)的區(qū)別小結(jié)

    本文主要介紹了React中super()和super(props)的區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解

    React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解

    這篇文章主要介紹了React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • useEvent顯著降低Hooks負(fù)擔(dān)的原生Hook

    useEvent顯著降低Hooks負(fù)擔(dān)的原生Hook

    這篇文章主要為大家介紹了useEvent顯著降低Hooks負(fù)擔(dān)的原生Hook示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 作為老司機(jī)使用 React 總結(jié)的 11 個(gè)經(jīng)驗(yàn)教訓(xùn)

    作為老司機(jī)使用 React 總結(jié)的 11 個(gè)經(jīng)驗(yàn)教訓(xùn)

    這篇文章主要介紹了作為老司機(jī)使用 React 總結(jié)的 11 個(gè)經(jīng)驗(yàn)教訓(xùn),需要的朋友可以參考下
    2017-04-04
  • 關(guān)于React Native報(bào)Cannot initialize a parameter of type''NSArray<id<RCTBridgeModule>>錯(cuò)誤(解決方案)

    關(guān)于React Native報(bào)Cannot initialize a parameter of type''NSArra

    這篇文章主要介紹了關(guān)于React Native報(bào)Cannot initialize a parameter of type'NSArray<id<RCTBridgeModule>>錯(cuò)誤,本文給大家分享解決方案,需要的朋友可以參考下
    2021-05-05

最新評(píng)論