react绑定实时数据

import React,{Component} from 'react';

/**

 * 约束性和非约束性组件

 * 非约束性组:  <input type='text' defaultValue={this.state.username}/>这个defaultValue其实就是原生DoM中的value属性

 * 这样写出来的组件,其value值就是用户输入的内容,React完全不管输入的过程

 * 约束性组件:  <input type='text' value={this.state.username} onChange={this.handleUsername}/>

 * 这里,value属性不再是一个写死的值,他是this.state.username,this.state.username是由this.handleChange负责管理的

 * 这个时候实际上input的value根本不是用户输入的内容。而是onChange时间触发之后,由于this.setState导致了一次重新渲染。不过React会优化这个

 */

class Hi extends Component{

    constructor(props){

      super(props);

      //react可以在这里定义数据

 

      this.state={

          //这里面写一个对象

        username:'1111111'

          }

    }

    handleUsername=(e)=>{

        this.setState({

            username:e.target.value

        })

    }

    render(){

        return (

        <div>

           <h1>react表单</h1>

           <input type='text' value={this.state.username} onChange={this.handleUsername}/>

           {this.state.username}

           <br/>

           <input type='text' defaultValue={this.state.username}/>

        </div>

     

        )

    }

}

export default Hi;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值