前端获取用户位置信息
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端获取用户位置信息相关的知识,希望对你有一定的参考价值。
参考技术A 获取key准备工作参考链接: https://lbs.amap.com/api/javascript-api/guide/abc/prepare地图初始化加载的定位只能获取到城市级别信息,如果想获取到具体的位置就要借助浏览器定位。高德JS API提供了AMap.Geolocation插件来实现定位,使用方式如下:
高德JS API提供的浏览器定位接口,融合了html5 Geolocation定位接口、精确IP定位服务,以及安卓定位sdk定位。
JS-API的Geolocation定位插件,融合了HTML5 Geolocation定位接口、精确IP定位服务,以及安卓定位sdk定位。其中与安卓定位sdk的结合使用适用于开发安卓系统的H5应用,需同时使用安卓定位sdk和JS-API。
(1)在PC端,因为原生接口成功率很低,JS-API会优先调用精确IP定位服务,在IP定位失败的时候,尝试使用浏览器原生定位接口进行定位,如果原生定位接口也定位失败,则返回error事件或回调error信息。定位成功之后我们会对浏览器定位的经纬度结果进行向高德坐标的转化,并对所有有效定位结果融合地址信息后返回complete事件或者回调complete信息。
(2)在移动端,如果开发者开启了sdk辅助定位,那么安卓手机上我们会优先尝试调用sdk的定位接口,失败之后优先调用浏览器原生定位接口进行定位,浏览器定位失败之后尝试进行精确IP定位,如果以上三种定位全部尝试失败则返回error事件或回调error信息,否则和PC端的一样,定位成功之后进行高德坐标转化和地址融合。
(3)我们在定位的回调或者事件响应中返回了message字段,message字段明确指出了每一步的成功和失败原因。
可以通过如下方法获取定位失败信息,之后根据定位错误信息参考
(1)Get ipLocation failed:IP精确定位失败,精确IP定位服务目前无法完全覆盖所有用户IP,失败率在5%左右;
(2)sdk定位失败:请检查sdk的key是否设置好,以及webview的定位权限及应用和系统的定位权限是否开启。
(3)浏览器定位失败,有多种情况:
注释:如果定位到城市即可满足需求,建议大家改用Geolocation.getCityInfo方法,可以根据IP返回用户所在城市的基本信息,包括省、市名称、adcode、citycode、城市中心点,城市矩形边界等信息。
以上是关于前端获取用户位置信息的主要内容,如果未能解决你的问题,请参考以下文章