React实现双向绑定示例代码

前言

React.js现在已经很流行了,不会React.js都不好意思说自己会前端了。

那么下面就来看看关于React双向绑定的实现。

双向绑定的使用:

组件需要mixins:引用LinkedStateMixin。它提供一个linkState方法

参数是state属性

双向绑定用valueLink={this.linkState(XX)}

linkState方法返回一个对象,有一个value属性,指定state的属性

还有一个requestChange回调方法,用来实现state的修改。参数是新值

可以理解成onchange的绑定方法。可以自己写一个linkState对象,value是state.XX requestChange里用setState()修改值。用valueLink={obj}来实现。

可以理解成this.linkState()实现的就是指定绑定值value 和change方法

valueLink属性实现了linkstate.value绑定到value requestChange方法绑定onChange

可以创建一个this.linkState('XX') value={XX.value} onchange={fn}方法内使用Xx.requestChange(e.target.value)

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

小结:linkState()方法提供state属性和change方法valueLink={}来实现value 和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 (

) } }) ; React.render(,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',render:function(){//绑定时属性从value换成valueLink值需要用this.linkState方法调用
    return (

    ); } }) React.render(,document.querySelector('#div2'));

/*底层原理

  • reactlink对象其实就一个value属性,和一个requestChange方法,value值 是state。方法实现修改state值
  • */
    var Box3=React.createClass({
    getInitialState:function(){
    return {
    name:'star',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(


    ) } }); React.render(,document.querySelector('#div3'));

/*valuelink

  • 它实际上实现的是状态的绑定和change事件的修改
  • requestChange方法接收值来实现state的修改
    */
    var Box4=React.createClass({
    mixins:[React.addons.LinkedStateMixin],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 (

    ) } }); React.render(,document.querySelector('#div4'));

------------------------ReactLink对象传递

可以向子组件传递:

子组件内可:

通过props来引用并绑定到valueLink上。

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

它们的变化 会同步到父组件的。并更新标签的。

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能有所帮助,如果有疑问大家可以留言交流。

相关文章

事件冒泡和事件捕获 起因:今天在封装一个bind函数的时候,发现el.addEventListener函数支持第三个参数...
js小数运算会出现精度问题 js number类型 JS 数字类型只有number类型,number类型相当于其他强类型语言...
什么是跨域 跨域 : 广义的跨域包含一下内容 : 1.资源跳转(链接跳转,重定向跳转,表单提交) 2.资源...
@ "TOC" 常见对base64的认知(不完全正确) 首先对base64常见的认知,也是须知的必须有...
搞懂:MVVM模式和Vue中的MVVM模式 MVVM MVVM : 的缩写,说都能直接说出来 :模型, :视图, :视图模...
首先我们需要一个html代码的框架如下: 我们的目的是实现ul中的内容进行横向的一点一点滚动。ul中的内容...