出于某种原因,我在 es6 类中为“this”获得了奇怪的值...
'use strict';
class Clicker {
constructor(element) {
this.count = 0;
this.elem = element;
this.elem.addEventListener('click', this.click);
// logs Clicker { count:0, elem: button#thing} as expected
console.log(this);
}
click() {
// logs <button id="thing">...</button> as unexpected...
console.log(this);
this.count++;
}
}
var thing = document.getElementById('thing');
var instance = new Clicker(thing);
<button id="thing">Click me</button>
问题:
为什么 Clickers 的 click 方法中的“this”指的是 dom 节点而不是 ... 本身?
更重要的是,如果我不能使用“this”来做到这一点,我如何从它的“click”方法中引用 Clickers 的 count 属性?