在网站中使用Google Map API V3版本,按照网站https://developers.google.com/maps/documentation/javascript/tutorial?hl=zh-cn中的例子,代码如下:
<!DOCTYPE html>
<html>
<head>
<title>GoogleMap</title>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
html { height: 100% }
body { height: 100%; margin: 0px; padding: 0px }
#map_canvas { height: 100% }
</style>
<script type="text/javascript" src="https://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
function initialize() {
var latlng = new google.maps.LatLng(-34.397, 150.644);
var myOptions = {
zoom: 8,
center: latlng,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_canvas"),myOptions);
}
</script>
</head>
<body οnlοad="initialize()">
<div id="map_canvas" style="width:100%; height:100%"></div>
</body>
</html>
运行时,总是会出现“google未定义”的错误提示,在网上搜索了很久,大都是说这是google本身的问题,过段时间可能就好了。但是还是不甘心,继续寻找解决方案,终于,柳暗花明。
解决方法很简单,只需要将载入Google Map API的那句代码中的" https ”协议改为" http ”即可。
即将 <script type="text/javascript" src="https://maps.google.com/maps/api/js?sensor=false"></script>
改为 <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
真是好无语的答案。
不过,深思一下,为什么会因为一个协议的问题而出现"google 未定义"的错误呢?
个人猜想,可能是因为https协议进行了加密保护,限制了我们的访问权限。但看到网上也有说直接用https协议可以成功运行的,其中缘由就不得而知了。
这个问题还有待进一步的研究。