我有以下代码
var utility = function() {
this.table = null;
this.parsedData = null;
}
utility.prototype.fetchData = function(url, query) {
var self = this;
var params = null;
if (query)
params = query;
$.ajax({
url: url,
data: params
})
.done(function(resp) {
resp = JSON.parse(resp);
if (resp.resp === 200) {
self.parsedData = resp.data;
}
});
return this;
};
我使用下面的事件处理程序调用它
var utilityObj = new utility();
$('#section').on('change', function() {
var self = this;
$.ajax({
url: 'api/get_tests.php',
method: 'GET',
data: {
section_id: this.value
}
}).done(function(resp) {
/* some other function calls here for dom manipulation */
utilityObj.fetchData('api/get_sections_tasks.php', {
section_id: self.value
});
});
});
在运行fetchData方法时,我发现parsedData仍然保持为null,我无法弄清楚我的代码中是否存在错误。任何帮助将非常感激。感谢。
这是在fetchData上收到的响应,它是正确的
{
"resp": 200,
"data": [{
"Id": 1,
"user_id": 1,
"section_id": 1,
"img": "\/uploads\/112015\/0b3eb1cc2a3473453b2be00091fc9a2f.jpg",
"title": "0",
"description": "dsafds",
"workflow": "Doing",
"created": "0000-00-00 00:00:00",
"updated": "0000-00-00 00:00:00"
}, {
"Id": 2,
"user_id": 1,
"section_id": 1,
"img": "\/uploads\/112015\/8bf91b2aa69222d8a337b98b67a486d0.jpg",
"title": "0",
"description": "sdafsdfa",
"workflow": "Backlog",
"created": "0000-00-00 00:00:00",
"updated": "0000-00-00 00:00:00"
}]
}
答案 0 :(得分:0)
在这段代码中
var utilityObj = new utility();
$('#section').on('change', function() {
var self = this;
$.ajax({
url: 'api/get_tests.php',
method: 'GET',
data: {
section_id: this.value
}
}).done(function(resp) {
/* some other function calls here for dom manipulation */
utilityObj.fetchData('api/get_sections_tasks.php', {
section_id: self.value
});
});
});
在此之前尝试console.log(self.value)
utilityObj.fetchData('api/get_sections_tasks.php', {
section_id: self.value
});
我认为这是问题所在。但我不确定。