我正在尝试在我的网站上使用的 map 上使用方向,但是不断弹出一个错误,而且我不知道如何消除它!
未捕获ReferenceError:未定义directionsService
这是我使用的代码
$(window).load(function () {
var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var map;
});
$(window).load(function () {
initialize();
});
function initialize() {
directionsDisplay = new google.maps.DirectionsRenderer();
var chicago = new google.maps.LatLng(41.850033, -87.6500523);
var mapOptions = {
zoom:7,
mapTypeId: google.maps.MapTypeId.ROADMAP,
center: chicago
}
map = new google.maps.Map(document.getElementById("map"), mapOptions);
directionsDisplay.setMap(map);
directionsDisplay.setPanel(document.getElementById("directionsPanel"));
}
function calcRoute() {
var start = new google.maps.LatLng(54.986136, -1.537945);
var end = new google.maps.LatLng(41.850033, -87.6500523);
var request = {
origin:start,
destination:end,
travelMode: google.maps.TravelMode.DRIVING
};
console.log(request);
if (request==true)
{
console.log("REQUEST");
}
console.log(JSON.stringify(request));
directionsService.route(request, function(result, status) {
if (status == google.maps.DirectionsStatus.OK) {
if (!response.routes[0].copyrights) {
response.routes[0].copyrights = "Copyrights unknown.";
}
console.log("ALL GOOD!");
directionsDisplay.setDirections(result);
}
else
{
console.log("NOT-GOOD!");
}
});
}
最佳答案
删除此行中的var-keyword:
var directionsService = new google.maps.DirectionsService();
当您使用var-keyword时,变量
directionsService
仅在函数内部可见,但是您需要一个全局变量(在任何范围内可见)