react中的ref

ref

1.定义

用来操作普通DOM元素和子组件

2.操作普通DOM元素

  • 方式一
{/* 方式一 */}
<div ref="div"></div>
 <button className="btn btn-primary" onClick={()=>this.send()}>操作DOM元素</button>
 send(){
        // console.log(this.refs.div);
        this.refs.div.style.width = '100px';
        this.refs.div.style.height = '100px';
        this.refs.div.style.background = 'pink';
    }
  • 方式二
 {/* 方式二 */}
{/* 系统自动注入了一个参数: 该参数表示的是当前普通元素,*/}
<div ref={dom=>this.add=dom}></div>
<button className="btn btn-primary" onClick={()=>this.send()}>操作DOM元素</button>
send(){
        // 方式二:
        // console.log(this.add);
        this.add.innerHTML = '中原一点红';
        this.add.style.color = 'red';
}
  • 方式三
 {/* 方式三 */}
<div ref={this.divRef}></div>
<button className="btn btn-primary" onClick={()=>this.send()}>操作DOM元素</button>
 send(){
        // 方式三
        // console.log(this.divRef.current);
        this.divRef.current.innerHTML = '王一博';
        this.divRef.current.style.background = 'green';
 }

3.操作子组件

<button className="btn btn-success" onClick={()=>this.change()}>通过ref属性操作子组件</button>
<Child ref={dom=>this.child=dom} />
  change(){
        // console.log(this.child);
        // console.log(this.child.state.name);
        this.child.message();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值