我有一个构造函数,它注册一个事件处理程序:
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)
但它表现出同样的问题.
如何访问正确的对象?
我注意到,似乎没有明确解释this关键字是什么以及如何在Stack Overflow站点上的JavaScript中正确(和错误地)使用它.
我亲眼目睹了一些非常奇怪的行为,并且无法理解为什么会发生这种行为.
this工作如何以及何时使用?
我需要this从我的setInterval处理程序访问
prefs: null,
startup : function()
{
// init prefs
...
this.retrieve_rate();
this.intervalID = setInterval(this.retrieve_rate, this.INTERVAL);
},
retrieve_rate : function()
{
var ajax = null;
ajax = new XMLHttpRequest();
ajax.open('GET', 'http://xyz.com', true);
ajax.onload = function()
{
// access prefs here
}
}
Run Code Online (Sandbox Code Playgroud)
我如何访问this.prefs ajax.onload?
我有一个从后端获取数据的 Angular 组件。
这是组件的代码
export class MessagesComponent implements OnInit {
constructor(private _router: Router, private http: HttpClient) {
}
timer: any;
chats: any;
autoresize: boolean = false;
chatId: number;
moment: any = moment;
chatMessages: any;
messageToSend: string;
messageObject: CreateMessageDto = new CreateMessageDto();
ngOnInit(): void {
this.getChatsList();
}
getChatsList(): any {
var reqHeader = new HttpHeaders({
'Content-Type': 'application/json',
Authorization: 'Bearer ' + localStorage.getItem('jwt'),
});
return this.http
.get(environment.baseUrl + '/Chat/GetUserChats', {
headers: reqHeader,
})
.subscribe((data: any) => {
this.chats = data.reverse();
this.getChatId(data[0].id);
}); …Run Code Online (Sandbox Code Playgroud)