search

Home  >  Q&A  >  body text

javascript - Problem with click event listening arrow function in React?

Overview

I just learned the front-end not long ago, and I have some questions about the writing method of event monitoring in React.
The writing methods I know are:

hanlde = (e)=> {

}
<button onClick={(e)=>this.handleClick(e)}>

</button>

question

What I don’t understand is the third way of writing

<button onClick={(e)=>this.handleClick(e)}>
</button>

I personally think that arrow function and bind should be different ways of writing the same thing. But I wrote a demo

var name = 'outside'

var obj = {
  name: 'inside',
  getName1: function() {
    return function() {
      return this.name;
    };
  },
  getName2: function() {
    var func = function(s) {
      return function() {
        return s;
      }
    };
    return func(this.name);
  },
  getName3: function () {
    var func = ()=> this.name;
    return func;
  },
  getName4: function () {
    var func = function() {
      return this.name;
    };
    func = func.bind(this);
    return func;
  },
  getName5 :function () {
    var func = function() {
      return this.name;
    };
    var func2 = ()=>func();
    return func2;
  }
};
console.log(obj.getName1()());//undefine或outside
console.log(obj.getName2()());//inside 通过闭包解决
console.log(obj.getName3()());//inside 通过箭头函数
console.log(obj.getName4()());//inside 通过bind函数
console.log(obj.getName5()());//undefine或outside ???不理解

In getName3, 4, and 5, what getName5 returns is not inside? ?
Maybe the problem lies in my misunderstanding of arrow functions and bind?
Hope to get guidance from seniors

滿天的星座滿天的星座2792 days ago1032

reply all(3)I'll reply

  • phpcn_u1582

    phpcn_u15822017-05-19 10:33:08

    The arrow function in 5 does not bind this when calling func, so this of func points to window
    Just change it to this

      getName5 :function () {
        var func = function() {
          return this.name;
        }.bind(this);
        var func2 = ()=>func();
        return func2;
      }

    Or this:

      getName5 :function () {
        var func = () => this.name;
        var func2 = () => func();
        return func2;
      }

    reply
    0
  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-05-19 10:33:08

    Newly defined functions have their own this value. In non-strict mode in the browser, this this points to the window. If a function is called as an object method, its this points to the object on which it was called. In the example, the getName5()中的函数func, 并非作为obj object method is called, therefore, its this points to window. Nothing to do with arrow functions.

    var name = 'outside'
    var obj = {
      name: 'inside',
      getName: function () {
        var func = function () {
          return this.name
        }
        return func()
      }
    }
    console.log(obj.getName()) // outside

    reply
    0
  • 为情所困

    为情所困2017-05-19 10:33:08

    @Xeira is right, when the arrow function is defined, this within the lexical scope is bound to its outer lexical scope, while ordinary functions are specifically bound when they need to be called. It is recommended to read the explanation about this in You-Dont-Know-JS, it is very clear

    reply
    0
  • Cancelreply