react input绑定数组值,并且支持输入

react input绑定数组值,并且支持输入

//react通过input修改数组里的某一个值
import React ,{Component} from 'react';
import { Input } from 'antd';
class Demo4 extends Component{
    constructor(props){
        super(props);
        this.state = {
            arr:[
                {
                    name:'lili',
                    age:'18',
                    sex:'女'
                }, {
                    name:'cyli',
                    age:'16',
                    sex:'男'
                }, {
                    name:'coco',
                    age:'20',
                    sex:'女'
                }
            ],
        };
    }

    inputChange(item,index,e){
        console.log("修改后的值为:",e.target.value);
        const { arr } = this.state;
        arr[index]['name'] = e.target.value;
        let newArr = arr;
        this.setState({
            arr:newArr
        })
    }
    render() {
        return (
            <div className='header'>
                <table border="1" style={{width:'100%'}}>
                    <tbody>
                    <tr>
                        <th>姓名</th>
                        <th>年龄</th>
                        <th>性别</th>
                    </tr>
                    {
                        this.state.arr?
                            this.state.arr.map((item,index)=>{
                                return (
                                    <tr key={index}>
                                        <td><Input value={item.name} onChange={this.inputChange.bind(this,item,index)}/></td>
                                        <td><Input value={item.age}/></td>
                                        <td><Input value={item.sex}/></td>
                                    </tr>
                                )
                            }):null
                    }
                    </tbody>
                </table>
            </div>
        )
    }
}

export default Demo4;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值