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 相关文章推荐
javascript的对话框详解与参数
Mar 08 Javascript
js 浏览本地文件夹系统示例代码
Oct 24 Javascript
实现隔行换色效果的两种方式【实用】
Nov 27 Javascript
原生js实现日期计算器功能
Feb 17 Javascript
ES6新特性之类(Class)和继承(Extends)相关概念与用法分析
May 24 Javascript
vue 封装自定义组件之tabal列表编辑单元格组件实例代码
Sep 07 Javascript
vue-cli创建的项目,配置多页面的实现方法
Mar 15 Javascript
最后说说Vue2 SSR 的 Cookies 问题
May 25 Javascript
微信小程序wx.uploadfile 本地文件转base64的实现代码
Jun 28 Javascript
JQuery模拟实现网页中自定义鼠标右键菜单功能
Nov 14 jQuery
Vue组件通信的几种实现方法
Apr 25 Javascript
Vue之beforeEach非登录不能访问的实现(代码亲测)
Jul 18 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
IIS环境下快速安装、配置和调试PHP5.2.0
2006/12/17 PHP
php多进程中的阻塞与非阻塞操作实例分析
2020/03/04 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
2007/03/10 Javascript
Javascript valueOf 使用方法
2008/12/28 Javascript
简洁短小的 JavaScript IE 浏览器判定代码
2010/03/21 Javascript
javascript 闭包
2011/09/15 Javascript
单击浏览器右上角的X关闭窗口弹出提示的小例子
2013/06/12 Javascript
js特效,页面下雪的小例子
2013/06/17 Javascript
学习JavaScript正则表达式
2015/11/13 Javascript
JavaScript函数内部属性和函数方法实例详解
2016/03/17 Javascript
微信小程序 利用css实现遮罩效果实例详解
2017/01/21 Javascript
jQuery实用密码强度检测
2017/03/02 Javascript
详解webpack解惑:require的五种用法
2017/06/09 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
react native仿微信PopupWindow效果的实例代码
2017/08/07 Javascript
使用Webpack提升Vue.js应用程序的4种方法(翻译)
2019/10/09 Javascript
微信小程序获取当前时间及星期几的实例代码
2020/09/20 Javascript
[01:59]游戏“zheng”当时试玩会
2019/08/21 DOTA
Python实现的简单读写csv文件操作示例
2018/07/12 Python
关于django 1.10 CSRF验证失败的解决方法
2019/08/31 Python
使用Python内置模块与函数进行不同进制的数的转换
2020/04/26 Python
解决pymysql cursor.fetchall() 获取不到数据的问题
2020/05/15 Python
Python爬取某平台短视频的方法
2021/02/08 Python
python学习之使用Matplotlib画实时的动态折线图的示例代码
2021/02/25 Python
在HTML5 canvas里用卷积核进行图像处理的方法
2018/05/02 HTML / CSS
Html5大文件断点续传实现方法
2015/12/05 HTML / CSS
HTML5中原生的右键菜单创建方法
2016/06/28 HTML / CSS
中学生家长评语大全
2014/04/16 职场文书
学雷锋的心得体会
2014/09/04 职场文书
违反交通法规检讨书
2014/09/10 职场文书
2014年药店店长工作总结
2014/11/17 职场文书
写景作文评语集锦
2014/12/25 职场文书
员工安全责任协议书
2016/03/22 职场文书
Golang之sync.Pool使用详解
2021/05/06 Golang
Python使用protobuf序列化和反序列化的实现
2021/05/19 Python
pnpm对npm及yarn降维打击详解
2022/08/05 Javascript