程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> javascript-關於百度地圖動態傳輸覆蓋物坐標的問題?

javascript-關於百度地圖動態傳輸覆蓋物坐標的問題?

編輯:編程解疑
關於百度地圖動態傳輸覆蓋物坐標的問題?

這是代碼:
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)
        })
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved