一、精准定位,需要https,需要用户手动同意。
在初次进入时进行定位,定位成功,保存定位所在城市。再次进入不定位,使用上一次的定位。
1.首先引入高德地图api
<script type="text/javascript" src="http://webapi.amap.com/maps?v=1.4.1&key=你自己的key"></script>
2.在页面加入一个div
<div id="container" style="display: none;"></div>
3.定位
var map = new AMap.Map('container', {
resizeEnable: true
});
//定位
if(localStorage.getItem("xcity") != null || localStorage.getItem("xcity") != "") {//如果存储了city就使用上一次存储的city
var xcity = localStorage.getItem("xcity")
} else { //否则重新定位
map.plugin('AMap.Geolocation', function() {
geolocation = new AMap.Geolocation({
enableHighAccuracy: true, //是否使用高精度定位,默认:true
timeout: 10000, //超过10秒后停止定位,默认:无穷大
noIpLocate: 0,
maximumAge: 0, //定位结果缓存0毫秒,默认:0
convert: true, //自动偏移坐标,偏移后的坐标为高德坐标,默认:true
showButton: false, //显示定位按钮,默认:true
buttonPosition: 'LB', //定位按钮停靠位置,默认:'LB',左下角
buttonOffset: new AMap.Pixel(10, 20), //定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
showMarker: false, //定位成功后在定位到的位置显示点标记,默认:true
showCircle: false, //定位成功后用圆圈表示定位精度范围,默认:true
panToLocation: false, //定位成功后将定位到的位置作为地图中心点,默认:true
zoomToAccuracy: false //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
});
map.addControl(geolocation);
geolocation.getCurrentPosition();
AMap.event.addListener(geolocation, 'complete', onComplete); //返回定位信息
AMap.event.addListener(geolocation, 'error', onError); //返回定位出错信息
});
function onComplete(data) {
var xcity = data.addressComponent.city //定位的城市名称
//经纬度
var lng = data.position.getLng()
var lat = data.position.getLat()
localStorage.setItem("xcity", xcity) //把定位存在localStorage,下次进入不会重新定位
}
//解析定位错误信息
function onError(data) {
// alert("定位失败")
var xcity = "青岛市" //在这里可以添加一个默认城市,在定位出错之后使用此默认城市(或者返回定位出错)
}
}
//在这里写获取定位之后的ajax
//比如获取离我最近的景点地区
4.在手动选择城市之后更改localStorage
二、只获得城市的定位,缺点:不精准,有几率出错。优点:不弹窗,http也可以使用
1.2.4.同上
3.定位
if(localStorage.getItem("xcity") == null || localStorage.getItem("xcity") == "") { //如果存储了city就使用上一次存储的city
var xcity = localStorage.getItem("xcity")
} else { //否则重新定位
map.getCity(function(data) {
if(data['province'] && typeof data['province'] === 'string') {
var xcity = data['city'] || data['province']
localStorage.setItem("xcity", xcity) //把定位存在localStorage,下次进入不会重新定位
}
});
}
//写获取定位之后的ajax