我有一个构造函数,它注册一个事件处理程序:
function MyConstructor(data, transport) {
this.data = data;
transport.on('data', function () {
alert(this.data);
});
}
// Mock transport object
var transport = {
on: function(event, callback) {
setTimeout(callback, 1000);
}
};
// called as
var obj = new MyConstructor('foo', transport);Run Code Online (Sandbox Code Playgroud)
但是,我无法data在回调中访问已创建对象的属性.它看起来this并不是指创建的对象,而是指另一个对象.
我还尝试使用对象方法而不是匿名函数:
function MyConstructor(data, transport) {
this.data = data;
transport.on('data', this.alert);
}
MyConstructor.prototype.alert = function() {
alert(this.name);
};
Run Code Online (Sandbox Code Playgroud)
但它表现出同样的问题.
如何访问正确的对象?
也许我错过了一些东西,但我无法弄清楚如何从点击回调中调用Listviewclass的方法之一.
这是代码:
function Listview(el, cb) {
this.element = el;
this.callback = cb;
this.select = function (element, index) {
...
};
this.selectElement = function (element) {
...
};
this.unselectCurrentElement = function () {
...
};
this.element.find('li').click(function () {
// Here I want to call for example the selectElement method
// but how?
// The This keyword reference the "li" element
});
this.element.addClass("Listview");
this.select(this.element, 0);
};
Run Code Online (Sandbox Code Playgroud)