React事件处理(学习笔记)

<script type="text/babel">
    //创建组件
    class Demo extends React.Component {
        /* 
            (1).通过onXxx属性指定事件处理函数(注意大小写)
                    a.React使用的是自定义(合成)事件, 而不是使用的原生DOM事件——为了更好的兼容性
                    b.React中的事件是通过事件委托方式处理的(委托给组件最外层的元素) ——为了的高效
            (2).通过event.target得到发生事件的DOM元素对象 ——不要过度使用ref
         */
        //创建ref容器
        myRef = React.createRef()
        myRef2 = React.createRef()

        //展示左侧输入框的数据
        showData = (event) => {
          console.log(event.target);
          alert(this.myRef.current.value);
        }

        //展示右侧输入框的数据
        showData2 = (event) => {
          alert(event.target.value);
        }

        render() {
          return (
            <div>
              <input ref={this.myRef} type="text" placeholder="点击按钮提示数据"/>&nbsp;
              <button onClick={this.showData}>点我提示左侧的数据</button>&nbsp;
              {/*当数据源和事件源来自于同一节点的时候,可以通过event.target避免使用ref*/}
              <input onBlur={this.showData2} type="text" placeholder="失去焦点提示数据"/>&nbsp;
             </div>
            )
        }
    }

    //渲染组件到页面
    ReactDOM.render(<Demo a="1" b="2"/>, document.getElementById('test'))
</script>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容