React实现双向绑定示例代码
前言
React.js现在已经很流行了,不会React.js都不好意思说自己会前端了。
那么狼蚁网站SEO优化就来看看关于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事件的绑定。
以下是实现代码
/默认表单双向绑定 给每个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上。
也可以用this.props.linkname.requestChange()
来用方法修改值 。
它们的变化 会同步到父组件的。并更新标签的。
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能有所帮助,如果有疑问大家可以留言交流。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程