React 学习笔记:form表单(二)

    1.表单分受控组件和非受控组件
        受控组件:我们可以把两者结合起来,使 React 的 state 成为“唯一数据源”
        非受控组件:非受控组件将真实数据储存在 DOM 节点中
    2.受控组件
        1.<input>、 <textarea> 和 <select>
        2.使用:如何获取值以及更新值
          

  <input name="username" value={this.state.username} onChange={this.gaibian.bind(this)}>  
      方法1:
  gaibian(event){
       this.setState({
             username:event.target.value
       })
  }
       方法2:
  gaibian(event){
        this.setState({
             [event.target.name]:event.target.value
        })
  }


        3.<textarea> 不管是设置值还是获取值都使用value属性
        4.select

<select value={this.state.key} onChange={this.sel.bind(this)}>
            sel(event){
                this.setState({
                    key:event.target.value
                })
            }


        5.单选按钮
          

  <input type="radio" name='sex' value='nan' onChange={this.selsex.bind(this)}/> 男
            <input type="radio" name='sex' value='nv' onChange={this.selsex.bind(this)}/> 女

            selsex(event){
                // console.log(event.target.value)
                this.setState({
                    sex:event.target.value
                })
            }


        6.多选按钮

 <input type="checkbox" vaule="apple" onChange={this.friut.bind(this)}>
            <input type="checkbox" vaule="orange" onChange={this.friut.bind(this)}>
            <input type="checkbox" vaule="pie" onChange={this.friut.bind(this)}>

            friut(event){
                let cur = event.target.value;
                let arr = this.state.shuiguo;
                if(this.state.shuiguo.indexOf(cur) == -1 ){
                    arr.push(cur)
                    this.setState({
                        shuiguo:arr
                    })
                }else{
                    arr.splice(this.state.shuiguo.indexOf(cur),1)
                    this.setState({
                        shuiguo:arr                
                    })
                }
            }


        7.form标签上       

<form onSubmit={this.tijiao.bind(this)}>
     <input type="submit"  value="提交" />
<form>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值