這是代碼:
var data_info = [
[/*114.884832*/,/*23.836244*/,html.join("")],
[/*113.662722*/,/*24.732023*/,html.join("")],
[/*113.386763*/,/*23.142491*/,html.join("")],
[/*112.125238*/,/*23.276542*/,html.join("")]
]; //信息框內的內容
//動態傳數據失敗
var url = 'index.json';
var areaJson;
var getData = function () {
var lngCoord = areaJson["lng"];
var latCoord = areaJson["lat"];
for (var i=0;i<data_info.length;i++) {
data_info[i][0] = lngCoord[i];
data_info[i][1] = latCoord[i];
}
alert(data_info[0][0]); //114.884832
};
$.getJSON(url, function (data) {
areaJson = data;
getData();
});
這是JSON:
data_info裡的數據是4個覆蓋物的信息,我現在想用json代替覆蓋物的坐標,但是一直出不來。在getData函數內還可以獲取到data_info。但是在外面就獲取不到了。不知道哪裡錯了,求解答。
萬分感謝!如果我的問題不夠詳細,請列出,我補上!
ajax是異步的,你的外部代碼需要放到getgData裡面執行,否則需要用$.ajax配置async為false同步請求,然後return你需要的data_info外部才能獲取,或者改為回掉的形式
你外部代碼怎麼調用的也沒貼
function getDataInfo(callback) {
var data_info = [
[/*114.884832*/,/*23.836244*/, html.join("")],
[/*113.662722*/,/*24.732023*/, html.join("")],
[/*113.386763*/,/*23.142491*/, html.join("")],
[/*112.125238*/,/*23.276542*/, html.join("")]
]; //信息框內的內容
//動態傳數據失敗
var url = 'index.json';
var areaJson;
var getData = function () {
var lngCoord = areaJson["lng"];
var latCoord = areaJson["lat"];
for (var i = 0; i < data_info.length; i++) {
data_info[i][0] = lngCoord[i];
data_info[i][1] = latCoord[i];
}
alert(data_info[0][0]); //114.884832
callback(data_info)//////////////
};
$.getJSON(url, function (data) {
areaJson = data;
getData();
});
}
getDataInfo(function (data) {//居於回掉形式調用getDataInfo函數,如果你要同步的,直接改$.getJSON為$.ajax並且async:false改同步後return data_info
console.log(data)
})