最近本人在做一个微信的项目,使用的是百度地图,没有使用腾讯自家的地图。主要是觉得百度地图使用的比较方便一些。
在使用地图API将地址转成坐标时,刚开始使用的是ajax调用(方法如下:)
$.ajax({
url:"http://api.map.baidu.com/geocoder/v2/?address="+你的地址+"&output=json&ak=你的百度key",
type:"post",
async:false,
dataType:"jsonp",
success:function(data){
jhx=data.result.location.lng;
jhy=data.result.location.lat;
shoujianren();
},
error:function(XMLHttpRequest, textStatus, errorThrown){
}
发现了一个很大的问题,就是百度的这个接口使用的是异步处理的方法,所以你不管怎么设置成同步都是不行的。解决方法如下:
先引入百度想对应的js
<script type="text/javascript"
src="https://api.map.baidu.com/getscript?v=2.0&ak=你的百度key"></script>
<script type="text/javascript"
src="https://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>
<script type="text/javascript"
src="https://api.map.baidu.com/library/AreaRestriction/1.2/src/AreaRestriction_min.js"></script>
这几个个人测试是必须添加的。增加网页的加载速度(本人这边是下载下来放在本地的)
var myGeo = new BMap.Geocoder();
// 将地址解析结果显示在地图上,并调整地图视野
myGeo.getPoint(address, function(point){
var nus=JSON.stringify(point);
}, "南通市");