zoukankan      html  css  js  c++  java
  • React事件处理 事件绑定 事件对象

    React 元素的事件处理和 DOM 元素的很相似,但是有一点语法上的不同:

    • React 事件的命名采用小驼峰式,而不是纯小写。

    onClick  onChange

    • 使用 JSX 语法时你需要传入一个函数作为事件处理函数,而不是一个字符串。

    onClick={this.fn}

    • 类组件与函数组件绑定事件是差不多的,只是在类组件中绑定事件函数的时候需要用到this,代表指向当前的类的引用,在函数中不需要调用this

    export default class extends React.Component {

        clickHandle(e){

            console.log('点了')

        }

        render(){

            return (

                <div><button onClick = {this.clickHandle}>点我点我点我</button></div>

            )

        }

    }

     

    React中可以通过事件处理函数的参数获取到事件对象,它的事件对象叫做:合成事件,即兼容所有浏览器,无需担心跨浏览器兼容问题,此事件对象还拥有和浏览器原生事件相同的接口,包括 stopPropagation()和 preventDefault(),如果你想获取到原生事件对象,可以通过 e.nativeEvent 属性来进行获取

    export default class extends React.Component {

        clickHandle(e){

            // 获取原生事件对象

            console.log(e.nativeEvent)

        }

        render(){

            return (

                <div><button onClick = {this.clickHandle}>点我点我点我</button></div>

            )

        }

    }

    import React, { Component } from 'react'
    
    export default class Itemclass extends Component {
    
      render() {return (
          <div>
            类组件
            <button onClick={this.fn}>点击我试一下</button>
            <hr />
            <a href="http://www.baidu.com" onClick={this.fn2}>百度一下</a>
          </div>
        )
      }
    
      fn(evt) {
        // alert('弹出一下')
        console.log(evt)
        // 当前事件触的dom元素
        console.log(evt.target);
        console.log(evt.target.innerHTML);
    
        // 原生event事件对象
        console.log(evt.nativeEvent);
      }
    
      fn2(evt) {
        // 手动取消标签默认行为
        evt.preventDefault();
    
        console.log('fn2执行了');
      }
    }

    import React from 'react'; const Items = ({ title, num }) => { const fn = () => { alert('fn函数') } return ( <div> 我是一个函数组件 <button onClick={fn}>function 点击我试一下</button> </div> ); } export default Items;
    右侧打赏一下 代码改变世界一块二块也是爱
  • 相关阅读:
    ActiveReports 报表控件官方中文入门教程 (2)-创建、数据源、浏览以及发布
    SpreadJS 中应用 KnockoutJS 技术
    HTML5 Wijmo:控制 Wijmo Grid 插件的编辑模式
    Studio for WPF:使用 C1TileView 创建图片库
    随心所欲导出你的 UI 界面到 PDF 文件
    Studio for Winforms FlexGrid: 创建分类汇总
    Hibernate中事务中事务相关知识点
    Hibernate-一级缓存
    Hibernate-实体详解
    算法之旅-First之选择排序
  • 原文地址:https://www.cnblogs.com/ht955/p/14667147.html
Copyright © 2011-2022 走看看