美文网首页
React系列bind this

React系列bind this

作者: 芒果加奶 | 来源:发表于2017-07-04 15:51 被阅读0次

在实际开发中遇到事件不执行的情况,一直不理解bind函数,正好理理,代码如下

 handleClick() {
      this.setState({
        text: 'Clicked'
      });
    }

    render() {
      return <h1 onClick={this.handleClick}>
        {'Hello ' + this.state.text}
      </h1>;
    }

this.handleClickthis作用域的callback的问题,实际中this.state.text不会发生变化。
React官网上找到三个解决方案

在constructor中加上bind 使用箭头函数1 使用箭头函数2

还可以直接在onClick方法上bind

handleClick() {
      this.setState({
        text: 'Clicked'
      });
    }

    render() {
      return <h1 onClick={this.handleClick.bind(this)}>
        {'Hello ' + this.state.text}
      </h1>;
    }

bind函数的含义

**bind()方法会创建一个新函数,当这个新函数被调用时,它的this值是传递给bind()的第一个参数, 它的参数是bind()的其他参数和其原本的参数. **

bind() 最简单的用法是创建一个函数,使这个函数不论怎么调用都有同样的 this 值。JavaScript新手经常犯的一个错误是将一个方法从对象中拿出来,然后再调用,希望方法中的 this 是原来的对象。(比如在回调中传入这个方法。)如果不做特殊处理的话,一般会丢失原来的对象。从原来的函数和原来的对象创建一个绑定函数,则能很漂亮地解决这个问题.

总结下bind使用就是为了保证this时时刻刻指向当前对象。

相关文章

  • react系列-bind this

    原文链接:https://segmentfault.com/a/1190000007207233对于大多数前端开发...

  • React系列bind this

    在实际开发中遇到事件不执行的情况,一直不理解bind函数,正好理理,代码如下 this.handleClick中t...

  • React .bind()

    当使用es5时,是不需要用.bind()的。当使用es5 时,React会自动帮助我们给每一个function绑定...

  • react bind

    前置知识 原因:在temp作为中间量转换的时候丢失了this的指向 在react中 bind的原理同上方一致,在j...

  • react性能优化 不要再component的props中使用箭头函数或者bind,因为每次使用箭头函数和bind...

  • React bind this的五种方式介绍

    react中避免不了经常需要对this进行操作,而事件默认react是不被bind到当前react实例上的,需要手...

  • React (TypeScript)

    React with TypeScript 系列(一) --概述 React with TypeScript 系列...

  • react的bind

    问题描述 今天重构项目的路由代码,遇到了一个问题,在app.js 的文件中,我使用react-router路由如下...

  • react的bind(this)

    在调用this.setState()的时候出现了this为undefined的情况,如何处理。(四种写法,其中一种...

  • 面试官问:能否模拟实现JS的bind方法

    前言 用过React的同学都知道,经常会使用bind来绑定this。 那么面试官可能会问是否想过bind到底做了什...

网友评论

      本文标题:React系列bind this

      本文链接:https://www.haomeiwen.com/subject/zfkxhxtx.html