admin管理员组文章数量:1339774
I have some code to get calendar events and display them. The display is only updated if the events have changed, since the last call.
var calendar = {
events = null,
display_calendar_events : function (data) {
// Some display stuff...
},
get_events: function() {
// Get messages for calendar
$.getJSON("/ajax/get-events/", function(json){
var new_events = json.data;
// If events haven't changed, do nothing
if (this.events === new_events) {
return true;
}
// Events have changed.
// Save new events
this.events = new_events;
// Display new events
this.display_calendar_events(json);
});
},
}
I call this with:
calendar.get_queued_events();
The problem is, I'm getting the error "this.display_calendar_events is not a function" (last line of code). But if I change this line to:
calendar.display_canendar_events(josn)
it works. The storing of the old events with "this.events" works fine in both cases.
Can someone explain this to me? How can "this" work for some stuff and not others? Thanks.
I have some code to get calendar events and display them. The display is only updated if the events have changed, since the last call.
var calendar = {
events = null,
display_calendar_events : function (data) {
// Some display stuff...
},
get_events: function() {
// Get messages for calendar
$.getJSON("/ajax/get-events/", function(json){
var new_events = json.data;
// If events haven't changed, do nothing
if (this.events === new_events) {
return true;
}
// Events have changed.
// Save new events
this.events = new_events;
// Display new events
this.display_calendar_events(json);
});
},
}
I call this with:
calendar.get_queued_events();
The problem is, I'm getting the error "this.display_calendar_events is not a function" (last line of code). But if I change this line to:
calendar.display_canendar_events(josn)
it works. The storing of the old events with "this.events" works fine in both cases.
Can someone explain this to me? How can "this" work for some stuff and not others? Thanks.
Share Improve this question asked Feb 13, 2012 at 16:03 AineAine 2,7085 gold badges30 silver badges41 bronze badges 2-
2
Inside the callback,
this
refers to something else (thejqXHR
object afaik). – Felix Kling Commented Feb 13, 2012 at 16:04 - possible duplicate of What context is the jQuery.post callback function invoked in? – Felix Kling Commented Feb 13, 2012 at 16:05
2 Answers
Reset to default 10In a jQuery AJAX callback, this
references the ajax request object. Try using var self = this;
before your AJAX call, and in the callback use self.display_calendar_events()
.
Alternatively, you could just reference calendar.display_calendar_events()
directly. But that's not easily refactored like the self
method is.
When you call this.display_calendar_events() inside the ajax request you area ctually in a different context than your object. You have to do:
var calendar = {
events = null,
display_calendar_events : function (data) {
// Some display stuff...
},
get_events: function() {
var $this = this;
// Get messages for calendar
$.getJSON("/ajax/get-events/", function(json){
var new_events = json.data;
// If events haven't changed, do nothing
if ($this.events === new_events) {
return true;
}
// Events have changed.
// Save new events
$this.events = new_events;
// Display new events
$this.display_calendar_events(json);
});
},
}
本文标签: javascriptthisfunction is not a function errorbut function existsStack Overflow
版权声明:本文标题:javascript - this.function is not a function error, but function exists - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743603252a2508915.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论