我正在尝试向生成的 Google 地图添加一条折线。折线的坐标是使用 jQuery(getJSON 函数)从我的 Web 服务器上的 JSON 文件中获取的。但是,我在回调方面遇到了麻烦。我在一个单独的 JavaScript 文件中定义了三个函数,它们是:
function initMap(callback) {
map = new google.maps.Map(document.getElementById('map-canvas'), {
center: {lat: 34.397, lng: 150.644},
scrollwheel: false,
zoom: 2
});
callback();
}
.
function setPath(callback) {
$.getJSON('./expOneActivityData.json',
function (data) {
//Some looping contstruct to navigate through my JSON file.
}
})
callback();
};
.
function addPath() {
var trekLine = new google.maps.Polyline({
path: expeditionCoordinates,
geodisc: true,
stokeColor: '#FF0000',
strokeOpacity: 1.0,
strokeWeight: 2
});
trekLine.setMap(map);
}
expeditionCoordinates 是一个数组,每个元素都是一个具有纬度和经度属性的对象。这被声明为全局变量,值初始化发生在 setPath() 的循环中。
在我的 HTML 文件中,我有:
<script src="https://maps.googleapis.com/maps/api/js?key=myKey&callback=initMap">
当我尝试在脚本标记中将 initMap 替换为 initMap(setPath(addPath)) 时,我收到来自 Google 的 400 Bad 请求。当然,在脚本标签中只包含“callback=initMap”会给出:
TypeError: callback is not a function
与 initMap 定义中的callback() 一致发生。
那么如何将函数传递给 googleapis,其中函数本身也有回调呢? (顺便说一句,我的循环构造很好)。我尝试将“defer”添加到 googleapi 脚本标记以及链接到我的 JavaScript 文件的标记中。我删除了所有回调内容,只执行了循环。我希望 expeditionCoordinates 数组能够在执行 googleapi 脚本标记之前完成初始化,尽管这也不起作用(地图仍然加载,只是没有折线)。
我对 Javascript 相当陌生,它是异步的,尽管我确实了解它们是如何工作的,并且已经在基础水平上成功地使用了它们一周左右的时间。
(这实际上让我想到了一个附带问题。到目前为止,我只使用过一个回调。我期望类似的内容:
initMap(setPath)
因为 setPath 在其定义作为参数传递时没有附加 () ,因此不会立即执行。虽然向 setPath 添加一组括号,因为它也需要回调(addPath),但这意味着它确实会立即执行?)