React学习笔记(五)—— 事件绑定

1.直接绑定

事件名必须时小驼峰式的,语法:

<button onClick={function(){console.log('a')}}>按钮</button>
2.

语法:

export default class BindEvent extends React.Component{
    constructor(){
        super();
        this.state={}
    }
    render(){
        return <div>
            <button onClick={this.hello}>按钮</button>
        </div>
    }
    hello(){
        console.log('niddnhao')
    }
}
3.绑定多个事件
export default class BindEvent extends React.Component{
    constructor(){
        super();
        this.state={}
    }
    render(){
        return <div>
            <button onClick={()=>{this.hello(1); this.world(2)}}>按钮</button>
        </div>
    }
    hello(a){
        console.log(a)
    }
     world(a){
        console.log(a + '----')
    }
}
绑定事件实现数据实时更新
  • React中用this.setState({})更改数据并更新
export default class BindEvent extends React.Component{
    constructor(){
        super();
        this.state={
            msg:'haha'
        }
    }
    render(){
        return <div>
            <button onClick={(e) => { this.hello();}}>按钮</button>
            {this.state.msg}
        </div>
    }
    hello(){
        this.setState({msg :this.state.msg +=1})
    }
    
}
  • this.setState({})方法执行时异步的,如果要获取到最新的值,需要使用this.setState({},callback函数)
hello(){
        this.setState({
        	msg :this.state.msg+=1
        },()=>{
            console.log(this.state.msg)
        })
    }
  • 可以使用//#region和//#endregion将这两者之间的代码折叠起来
双向数据绑定
  • 方式一 onchange事件
<input type="text" style={{width:"100%"}} value={this.state.msg} onChange={(e)=>{this.textChange(e)}}/>
 
 textChange(e){
            this.setState({
                msg: e.target.value
            })
            
        }
  • 方式二 ref属性
<input type="text" ref="text" value={this.state.msg}} onChange={()=>{ textChange()}/>
 textChange(){
            this.setState({
                msg: this.refs.text.value
            })
            
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值