React编写input组件传参共用onChange

简介: 之前写页面上的input比较少,所以没有单提出来一个组件,今天研究了下input组件,但共用一个onChange的问题卡了一会儿,查了下发现几个比较好的方法,分享下:方法一Input组件let Input = React.

之前写页面上的input比较少,所以没有单提出来一个组件,今天研究了下input组件,但共用一个onChange的问题卡了一会儿,查了下发现几个比较好的方法,分享下:

方法一

Input组件

let Input = React.createClass({

    getInitialState: function() {
     
        return { }
    },
    
    render: function() { 
        return (
            <div className="inputwrapper">
                <input type="text" placeholder={this.props.placeholder} onChange={this.props.vauleChange.bind(null,this.props.name)}/>
            </div>

          );
        }
})

使用Input组件

let FormAdd = React.createClass({

    getInitialState: function() {
    
        return {  }
    },
   
    submit:function(){
    
        console.log(this.state);
        
    },
    
    vauleChange:function(name,e){
    
        console.log(name+e.target.value);
        this.setState({[name]:  e.target.value})
    },
  
    render: function() { 
 
        return (

            <div className="all">
                    <Input placeholder="请输入你的姓名" name="name" vauleChange={this.vauleChange}></Input>
                    <Input placeholder="请输入你的手机号" name="phone" vauleChange={this.vauleChange}> </Input>
                    <Input placeholder="请输入你的微信号" name="wechat" vauleChange={this.vauleChange}></Input>
                    <Input placeholder="请输入你的QQ号" name="qq" vauleChange={this.vauleChange}></Input>
                    <div className="rebtn" onClick={this.submit}></div>
                </div>
                      
            </div>

          );
        }
})

方法二

Input组件

let Input = React.createClass({

     getInitialState: function() {
     
        return { }
    },
    
    render: function() { 
    
        return (
            <div className="inputwrapper">
                <input type="text" placeholder={this.props.placeholder} name={this.props.name} onChange={this.props.vauleChange}/>
            </div>

          );
        }
})

使用Input组件

let FormAdd = React.createClass({

    getInitialState: function() {
    
        return {  }
    },
   
    submit:function(){
    
        console.log(this.state);
        
    },
    
    vauleChange:function(name,e){
    
        this.setState({[e.target.name]:  e.target.value});
        
        /*下面这种方式也可以
         var change = {};
         change[e.target.name] = e.target.value;
         this.setState(change);
        */
    },
    
   
    render: function() { 
 
        return (

            <div className="all">
                <Input placeholder="请输入你的姓名" name="name" vauleChange={this.vauleChange}></Input>
                <Input placeholder="请输入你的手机号" name="phone" vauleChange={this.vauleChange}> </Input>
                <Input placeholder="请输入你的微信号" name="wechat" vauleChange={this.vauleChange}></Input>
                <Input placeholder="请输入你的QQ号" name="qq" vauleChange={this.vauleChange}></Input>
                <div className="rebtn" onClick={this.submit}></div>
            </div>

          );
        }
})

注:setState({xxx:xxx}) 第一个参数默认会被认为是字符串,因为动态传递的是一个变量 要用[]中括号包裹

参考:React.js: Identifying different inputs with one onChange handler

目录
相关文章
|
3月前
|
存储 前端开发 JavaScript
react怎么实现跨页面传参
react怎么实现跨页面传参
47 2
|
4月前
|
资源调度 前端开发 JavaScript
React 的antd-mobile 组件库,嵌套路由
React 的antd-mobile 组件库,嵌套路由
42 0
|
3月前
|
存储 前端开发 中间件
React组件间的通信
React组件间的通信
17 1
|
3月前
|
前端开发 应用服务中间件 数据库
react服务端组件
react服务端组件
21 0
|
3月前
|
前端开发 JavaScript
快速上手React:从概述到组件与事件处理
快速上手React:从概述到组件与事件处理
|
4月前
|
前端开发 JavaScript API
React组件生命周期
React组件生命周期
76 1
|
4月前
|
资源调度 前端开发 JavaScript
React组件
React组件
42 0
|
4月前
|
存储 前端开发 JavaScript
探索 React Hooks 的世界:如何构建出色的组件(下)
探索 React Hooks 的世界:如何构建出色的组件(下)
探索 React Hooks 的世界:如何构建出色的组件(下)
|
4月前
|
缓存 前端开发 API
探索 React Hooks 的世界:如何构建出色的组件(上)
探索 React Hooks 的世界:如何构建出色的组件(上)
探索 React Hooks 的世界:如何构建出色的组件(上)
|
4月前
|
存储 前端开发 JavaScript
React组件中如何通讯
React组件中如何通讯
16 0