源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

React实现双向绑定示例代码

  • 时间:2020-05-24 08:40 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:React实现双向绑定示例代码
[b]前言[/b] React.js现在已经很流行了,不会React.js都不好意思说自己会前端了。 那么下面就来看看关于React双向绑定的实现。 [b]双向绑定的使用:[/b] 组件需要mixins:引用LinkedStateMixin。它提供一个linkState方法。 参数是state属性 双向绑定用[code]valueLink={this.linkState(XX)} [/code] linkState方法返回一个对象,有一个value属性,指定state的属性。 还有一个requestChange回调方法,用来实现state的修改。参数是新值 可以理解成onchange的绑定方法。可以自己写一个linkState对象,value是[code]state.XX requestChange[/code]里用[code]setState()[/code]来修改值。用[code]valueLink={obj}[/code]来实现。 可以理解成[code]this.linkState()[/code]实现的就是指定绑定值value 和change方法 valueLink属性实现了[code]linkstate.value[/code]绑定到value requestChange方法绑定onChange 可以创建[code]一个this.linkState('XX') value={XX.value} onchange={fn}[/code]方法内使用[code]Xx.requestChange(e.target.value) [/code] ------------------------- [b]小结:[/b][code]linkState()[/code]方法提供state属性和change方法。[code]valueLink={}[/code]来实现value 和change事件的绑定。 [b]以下是实现代码[/b]
/*默认表单双向绑定
   * 给每个input绑定change事件来实现修改state
   * 如果标签多了一个个绑定肯定是不行的,
   * 所以react 给我个提示了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模式的简单包装和约定。是其的简写方式
   * 1、需要mixins添加引用
   * 2、原先的value绑定换成valueLink。参数从this.state.XX换成this.linkState('XX')这样就可以了
   */
   /*ReactLink解析
   * LinkedStateMixin给组件添加一个linkState方法,参数是state属性名。
   * 它返回一个reactlink对象,包含state当前值和一个改变值 的回调.
   * reactlink 可以在组件间通过props传递
   */
   var Box2=React.createClass({
   mixins:[React.addons.LinkedStateMixin],//添加引用
   getInitialState:function(){
    return {
    name:'star',bool:true
    }
   },
   render:function(){//绑定时属性从value换成valueLink值需要用this.linkState方法调用
    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对象其实就一个value属性,和一个requestChange方法,value值 是state。方法实现修改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
   * 它实际上实现的是状态的绑定和change事件的修改
   * requestChange方法接收值来实现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对象传递 可以向子组件传递:
linkname={this.linkState('name')}
子组件内可:
<input type="text" valueLink={this.props.linkname} >
通过props来引用并绑定到valueLink上。 也可以用[code]this.props.linkname.requestChange()[/code]来用方法修改值 。 它们的变化 会同步到父组件的。并更新标签的。 [b]总结[/b] 以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能有所帮助,如果有疑问大家可以留言交流。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部