为什么我必须调用新的Chart()来从同一个类中触发一个方法(按照说法)?这是正确的方法吗?感谢。
function Chart(location, startDateString, endDateString) {
this.location = location;
this.startDateString = startDateString;
this.endDateString = endDateString;
}
Chart.prototype.fnDrawStaticChart = function(chartUrl, chartData) {
$.get(chartUrl, function() {
$('#'+chartData.wrapSpecId).attr('src', chartUrl);
});
}
Chart.prototype.fnDraw = function(fnStaticChartJSON, fnStaticChartImage) {
$.getJSON(fnStaticChartJSON, function(data) {
if (data.chartData.length > 0) {
$('#chartDiv').append($('#template').jqote(data, '@'));
$.each(data.chartData, function(index, chartData) {
var pkgLineId = chartData.wrapSpec2.pkgLineId.pkgLineId;
var wrapSpecId = chartData.wrapSpecId;
var startDate = data.startDate;
var endDate = data.endDate;
var chartUrl = fnStaticChartImage({
pkg_line_id: pkgLineId,
wrap_spec_id: wrapSpecId,
start_date: startDate,
end_date: endDate
});
this.fnDrawStaticChart(chartUrl, chartData); //can't do this.
new Chart().fnDrawStaticChart(chartUrl, chartData); CAN do this.
});
});
}
答案 0 :(得分:2)
这是一个简单的范围界定问题。 这个指向您传递给$ .each的函数。您必须将旧的this引用存储在另一个变量中:
Chart.prototype.fnDraw = function(fnStaticChartJSON, fnStaticChartImage) {
var self = this;
$.getJSON(fnStaticChartJSON, function(data) {
if (data.chartData.length > 0) {
$('#chartDiv').append($('#template').jqote(data, '@'));
$.each(data.chartData, function(index, chartData) {
var pkgLineId = chartData.wrapSpec2.pkgLineId.pkgLineId;
var wrapSpecId = chartData.wrapSpecId;
var startDate = data.startDate;
var endDate = data.endDate;
var chartUrl = fnStaticChartImage({
pkg_line_id: pkgLineId,
wrap_spec_id: wrapSpecId,
start_date: startDate,
end_date: endDate
});
self.fnDrawStaticChart(chartUrl, chartData);
new Chart().fnDrawStaticChart(chartUrl, chartData);
});
});
}