react 中父组件与子组件双向绑定问题


Posted in Javascript onMay 20, 2019

在项目中我们可能会遇到类似这样的场景,也就是父子组件的双向数据绑定

react 中父组件与子组件双向绑定问题

首先,先把在head中引入react.js、react-dom.js和可选择的babel.js(这里需要注意引用的顺序,react.js必须在react-dom.js之前)

<head>
  <script src="react.js"></script>
  <script src="react-dom.js"></script>
  <script src="babel.js"></script>
</head>

 在body里新建一个挂载点

<body>
  <div id='app'></div>
</body>

然后就可以开始写JSX了,注意script标签需注明type类型为"text/babel"或"text/jsx"

<script tpye='text/babel'>
//父组件
  class Father extends React.Component {
    constructor(props) {
      super(props)
      this.state = {
        fname: '父组件',
        fage: 18,
        key: '' 
      };
    }
    setFname(event) {
      this.setState({fname: event.target.value, key: event.target.value});  //设置fname值为input的value值;key用来监听值是否变化 
} setFage(event) { this.setState({fage: event.target.value, key: event.target.value}) } toData(data) { this.setState({fname: data.name}); this.setState({fage: data.age}); } render() { return ( <div> <table border="1" cellSpacing="0"> <tbody> <tr> <th colSpan="3">父组件数据</th> </tr> <tr> <td>name</td> <td>{this.state.nameFvalue}</td> <td><input value={this.state.fname} onChange={this.setFname.bind(this)}/></td> //受控组件当input值改变时触发方法setFname </tr> <tr> <td>age</td> <td>{this.state.ageFvalue}</td> <td><input value={this.state.fage} onChange={this.setFage.bind(this)}/></td> </tr> </tbody> </table><br>           <br>           //子组件标签里将父组件的数据传递给子组件,在子组件里利用props接收;key值变化时,子组件数据更新
          <Son key={this.state.key} fname={this.state.fname} fage={this.state.fage} toData={this.toData.bind(this)}></Son>  
        </div>
      )
    }
  }<br><br><br> //子组件<br><br> 
class Son extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
      sVname: this.props.fname, //将父组件传下来的值赋给sVname
      sVage: this.props.fage  
    }
  }
  sVname(ev) {
    console.log(ev.target)
    this.setState({
      sVname: ev.target.value
    })
  }
  sVage(ev) {
    this.setState({
      sVage: ev.target.value
    })
  }
  toData(data) {
    // console.log(svname)
    this.props.toData(data)
  }
  render() {
    return (
      <div>
        <button onClick={this.toData.bind(this, {name: this.state.sVname, age: this.state.sVage})}>点我传值
        </button>
        <table border="1" cellSpacing="0">
          <tbody>
          <tr>
            <th colSpan="3">子组件数据</th>
          </tr>
          <tr>
            <td>name</td>
            <td>{this.state.sVname}</td>
            <td><input value={this.state.sVname} onChange={this.sVname.bind(this)}/></td>
          </tr>
          <tr>
            <td>age</td>
            <td>{this.state.sVage}</td>
            <td><input value={this.state.sVage} onChange={this.sVage.bind(this)}/></td>
          </tr>
          </tbody>
        </table>
      </div>

    )
  }
}
</script>

总结

以上所述是小编给大家介绍的react 中父组件与子组件双向绑定问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
XENON基于JSON变种
Jul 27 Javascript
基于prototype扩展的JavaScript常用函数库
Nov 30 Javascript
使用Javascript接收get传递的值的代码
Nov 30 Javascript
JavaScript学习笔记之JS对象
Jan 22 Javascript
js实现鼠标感应向下滑动隐藏菜单的方法
Feb 20 Javascript
jQuery实现的多屏图像图层切换效果实例
May 07 Javascript
一看就懂:jsonp详解
Jun 01 Javascript
Js 获取、判断浏览器版本信息的简单方法
Aug 08 Javascript
webstrom Debug 调试vue项目的方法步骤
Jul 17 Javascript
javascript 代码是如何被压缩的示例代码
May 06 Javascript
JS箭头函数和常规函数之间的区别实例分析【 5 个区别】
May 27 Javascript
vue-preview动态获取图片宽高并增加旋转功能的实现
Jul 29 Javascript
vue element-ui之怎么封装一个自己的组件的详解
May 20 #Javascript
一文搞懂ES6中的Map和Set
May 20 #Javascript
详解vue 在移动端体验上的优化解决方案
May 20 #Javascript
vue-i18n结合Element-ui的配置方法
May 20 #Javascript
JS实现选项卡效果的代码实例
May 20 #Javascript
微信打开网址添加在浏览器中打开提示的办法
May 20 #Javascript
浅谈Vuex注入Vue生命周期的过程
May 20 #Javascript
You might like
php调用mysql存储过程
2007/02/14 PHP
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
2009/09/05 PHP
让PHP支持断点续传的源码
2010/05/16 PHP
PHP $_FILES函数详解
2011/03/09 PHP
PHP输入流php://input介绍
2012/09/18 PHP
php递归法读取目录及文件的方法
2015/01/30 PHP
PHP获取本周所有日期或者最近七天所有日期的方法
2018/06/20 PHP
phpwind放自动注册方法
2006/12/02 Javascript
设置iframe的document.designMode后仅Firefox中其body.innerHTML为br
2012/02/27 Javascript
setTimeout的延时为0时多个浏览器的区别
2012/05/23 Javascript
SeaJS入门教程系列之完整示例(三)
2014/03/03 Javascript
基于NodeJS的前后端分离的思考与实践(一)全栈式开发
2014/09/26 NodeJs
javascript实现简单的省市区三级联动
2015/05/14 Javascript
基于javascript简单实现对身份证校验
2021/01/25 Javascript
分享12个非常实用的JavaScript小技巧
2016/05/11 Javascript
详解JavaScript实现设计模式中的适配器模式的方法
2016/05/18 Javascript
jquery实现拖动效果
2016/08/10 Javascript
node.js学习之断言assert的使用示例
2017/09/28 Javascript
JavaScript 跨域之POST实现方法
2018/05/07 Javascript
关于vue-router的那些事儿
2018/05/23 Javascript
移动端手指操控左右滑动的菜单
2019/09/08 Javascript
Vue.js实现可编辑的表格
2019/12/11 Javascript
viewer.js实现图片预览功能
2020/06/24 Javascript
js实现详情页放大镜效果
2020/10/28 Javascript
Python中input和raw_input的一点区别
2014/10/21 Python
ubuntu17.4下为python和python3装上pip的方法
2018/06/12 Python
python-docx文件定位读取过程(尝试替换)
2020/02/13 Python
如何理解python面向对象编程
2020/06/01 Python
python绘制分布折线图的示例
2020/09/24 Python
linux系统下pip升级报错的解决方法
2021/01/31 Python
美国专业级皮肤病和spa品质护肤品的高级零售网站:SkinCareRx
2017/02/06 全球购物
来自世界上最好大学的在线课程:edX
2018/10/16 全球购物
岳父生日宴会答谢词
2014/01/13 职场文书
实习鉴定评语
2014/01/19 职场文书
创业计划书的写作技巧及要点
2014/01/31 职场文书
经贸韩语专业大学生职业规划
2014/02/14 职场文书