react通过ref获取dom节点信息

一、通过内敛样式函数的方式获取dom。此种方式在每次更新数据的时候都需要先将c元素置为null,所以需要 渲染两次。但是不会影响页面的展示。

 class Demo extends React.Component {
        showInfo = () => {
          console.log(this.input1);
        };
        render() {
          return (
            <div>
              {/*通过内联样式获取dom元素*/}
              <input ref={(c) => (this.input1 = c)} type="text"></input>
              <button onClick={this.showInfo}>点我提示输入数据</button>
            </div>
          );
        }
      }
      //2.渲染组件到页面
      ReactDOM.render(<Demo />, document.getElementById("test"));
}

二、通过函数回调的方式绑定的方式获取dom节点元素,

 class Demo extends React.Component {
        state = { isHot: true };
        showInfo = () => {
          console.log(this.input1);
        };

        changeWeather = () => {
          const { isHot } = this.state;
          this.setState({ isHot: !isHot });
        };

        saveInput = (c) => {
          this.input1 = c;
          console.log(c);
        };
        render() {
          const { isHot } = this.state;
          return (
            <div>
              {/*通过回调函数的方式获取dom元素*/}
              <h2>今天很{isHot ? "炎热" : "凉爽"}</h2>
              <input ref={this.saveInput} type="text"></input>
              <button onClick={this.showInfo}>点我提示输入数据</button>
              <button onClick={this.changeWeather}>点我改变天气颜色</button>
            </div>
          );
        }
      }

三、通过react组件中的createRef创建一个容器,将获取的dom节点数据放入容器中

class Demo extends React.Component {
        myref = React.createRef();

        showInfo = () => {
          alert(this.myref.current.value);
        };

        render() {
          return (
            <div>
              {/*通过createRef获取dom元素*/}
              <input ref={this.myref} type="text"></input>
              <button onClick={this.showInfo}>点我提示输入数据</button>
            </div>
          );
        }
      }

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

量化接口stockapi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值