React中的处理事件_React如何处理事件

时间: 2018-08-31阅读: 1175标签: react

今天我们主要说一下react是如何处理事件的。事件的处理是前端开发过程中非常重要的一部分,通过事件处理,我们可以响应用户的各种操作,从而实现一个富交互的应用。


react事件处理VS原生Dom事件处理

两者在事件处理方面极其类似,只是在一些语法上稍有不同: 
* React 事件绑定属性的命名采用驼峰式写法(如:onClick,onKeyUp),而不全是小写字母。 
* 如果采用 jsX 的语法你需要传入一个函数作为事件处理函数,而不是一个字符串(DOM 元素的写法)。

原生DOM事件写法:

<input type="button" onclick="fn()">

React中写法:

<input type="button" onClick={fn}>
  • 另外在React当中,return false不会阻止事件的默认行为,需要调用 e.preventDefault(); 例如,通常我们在 html 中阻止链接默认打开一个新页面,可以这样写:
<a href="#" onclick="console.log('点击链接'); return false">
  你来点我呵
</a>

而在React中要这样写:

function ActionLink() {
  function handleClick(e) {
    e.preventDefault();
    console.log('链接被点击');
  }

  return (
    <a href="#" onClick={handleClick}>
      点我
    </a>
  );
}


绑定事件处理函数的this问题

在以类继承的方法定义的组件中,事件处理函数的this指向的并不是当前组件。

class MyComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name:"老大",
            age: 0
        }
    }
    addOneClick(e) {
        e.preventDefault();
        /*此处的this并没有指向,所以会报错:
        * Uncaught TypeError: Cannot read property 'setState' of undefined*/
        this.setState({ age: this.state.age + 1 })
    }
    render() {
        return <div>
            <a href="#" onClick={this.addOneClick}>点我啊</a>
            {this.state.name}今年{this.state.age}岁了!
        </div>;
    }
}
var element = <MyComponent/>;
ReactDOM.render(
    element,
    document.querySelector("#wrap")
);

以上示例在点击链接时,会报错:Uncaught TypeError: Cannot read property ‘setState’ of undefined。因为this指向的并不是该组件。所以为了能方便调用当前组件的其他属性或方法,需要将this指向为当前实例


绑定事件处理函数的this到当前组件,有四种方法:

1、通过bind方法进行原地绑定,从而改变this指向:

render() {
    return <div>
        <a href="#" onClick={this.addOneClick.bind(this)}>点我啊</a>
        {this.state.name}今年{this.state.age}岁了!
    </div>;
}

该种方式写起来比较简单,但是每次执行bind方法都会生成一个新的函数,势必会有额外的开销,明显这并不是一种好的方法。


2、通过箭头函数

render() {
    return <div>
        <a href="#" onClick={e => this.addOneClick(e)}>点我啊</a>
        {this.state.name}今年{this.state.age}岁了!
    </div>;
}

这种写法也不是特别麻烦,不过依然也会有一丢丢的性能开销问题。


3、在constructor中提前对事件进行绑定:

class MyComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name:"老大",
            age: 0
        };
        //在此处提前绑定
        this.addOneClick=this.addOneClick.bind(this);
    }
    addOneClick(e) {
        e.preventDefault();
        this.setState({ age: this.state.age + 1 })
    }
    render() {
        return <div>
            <a href="#" onClick={this.addOneClick}>点我啊</a>
            {this.state.name}今年{this.state.age}岁了!
        </div>;
    }
}
var element = <MyComponent/>;
ReactDOM.render(
    element,
    document.querySelector("#wrap")
);

以上这种写法自带尿点。虽然没有额外开销,但写起来有些复杂。以后要对每个事件都要在构造器中再进行一次绑定。


4、将事件的写法改为箭头函数的形式

class MyComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name:"老大",
            age: 0
        }
    }
    //在此处采用箭头函数写法
    addOneClick=(e) => {
        e.preventDefault();
        this.setState({ age: this.state.age + 1 })
    }
    render() {
        return <div>
            <a href="#" onClick={this.addOneClick}>点我啊</a>
            {this.state.name}今年{this.state.age}岁了!
        </div>;
    }
}
var element = <MyComponent/>;
ReactDOM.render(
    element,
    document.querySelector("#wrap")
);

是不是很不错?


向事件处理函数传递参数

现在咱们要将之前为年龄加1的案例进行一下调整!调整为当点击时根据传递的参数来决定加几!比如传2,点击一次加2。传递参数有两种方法:


1、通过箭头函数

其实也就是在箭头函数内,调用事件处理函数。

class MyComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name:"老大",
            age: 0
        }
    }
    addOneClick(num,e){
        e.preventDefault();
        this.setState({ age: this.state.age + num })
    }
    render() {
        return <div>
            <a href="#" onClick={(e) => this.addOneClick(2, e)}>点我啊</a>
            {this.state.name}今年{this.state.age}岁了!
        </div>;
    }
}
var element = <MyComponent/>;
ReactDOM.render(
    element,
    document.querySelector("#wrap")
);

2、通过bind

  • 通过 bind 方式向监听函数传参,在类组件中定义的监听函数,事件对象 e 要排在所传递参数的后面
class MyComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name:"老大",
            age: 0
        }
    }
    addOneClick(num,e){
        e.preventDefault();
        this.setState({ age: this.state.age + num })
    }
    render() {
        return <div>
            <a href="#" onClick={this.addOneClick.bind(this,2)}>点我啊</a>
            {this.state.name}今年{this.state.age}岁了!
        </div>;
    }
}
var element = <MyComponent/>;
ReactDOM.render(
    element,
    document.querySelector("#wrap")
);


来源:https://blog.csdn.net/u012149969/article/details/82215494


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/1044

关闭

如何使用React搭建前端?

首先说明node.js、npm、cnpm分别是做什么的?node.js简单的说 Node.js 就是运行在服务端的 JavaScript,安装了node.js默认安装了npm,可以使用npm -v查看是否安装。

21 项优化 React App 性能的技术

在 React 内部,React 会使用几项巧妙的小技术,来优化计算更新 UI 时,所需要的最少的更新 DOM 的操作。在大多数情况下,即使你没有针对性能进行专项优化,React 依然很快,但是仍有一些方法可以加速 React 应用程序

关于创建React App的8个有趣事实

你所知道的一些事情,你可能不知道的一些事情Create React App是搭建React项目的快速方法。这样我们可以重点放在代码上,而不是构建工具上。

React中使用CSS

在组件中直接使用style:不需要组件从外部引入css文件,直接在组件中书写。在组件中引入[name].css文件:需要在当前组件开头使用import引入css文件。在组件中引入[name].scss文件:引入react内部已经支持了后缀为scss的文件,所以只需要安装node-sass即可

10分钟快速了解 React 基础

如果你还不会 React,希望本文可以帮你快速了解 React.js 的基础知识。使用 create-react-app 工具快速创建 React SPA。render 函数中提到了 JSX,简单的看,就是一个可以在 js 中写 html

如何写出漂亮的 React 组件

在Walmart Labs的产品开发中,我们进行了大量的Code Review工作,这也保证了我有机会从很多优秀的工程师的代码中学习他们的代码风格与样式。在这篇博文里我会分享出我最欣赏的五种组件模式与代码片。不过我首先还是要谈谈为什么我们需要执着于提高代码的阅读体验

Context - React跨组件访问数据的利器

Context提供了一种跨组件访问数据的方法。它无需在组件树间逐层传递属性,也可以方便的访问其他组件的数。在经典的React应用中,数据是父组件通过props向子组件传递的

react中实现可拖动div

把拖动div功能用react封装成class,在页面直接引入该class即可使用。title为可拖动区域。panel为要实现拖动的容器。优化了拖动框超出页面范围的情况,也优化了拖动太快时鼠标超出可拖动区域的情况

react中PureComponent浅对比策略

PureComponent实现了Component中没有实现的shouComponentUpdata()方法,会对state和props进行一次浅对比,本文介绍一下浅对比策略,源码中,实现浅对比的函数是:shallowEqual()

React事件绑定几种方法测试

es6写法的类方法默认没有绑定this,不手动绑定this值为undefined。因此讨论以下几种绑定方式。构造函数constructor中用bind绑定、在调用的时候使用bind绑定this、在调用的时候使用箭头函数绑定this、使用属性初始化器语法绑定this

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!