React Native获取地理位置(获取具体城市、经纬度)

来源:互联网 发布:外汇交易员的收入知乎 编辑:程序博客网 时间:2024/06/04 17:45

并不是所有的APP都要获取你当前的地理位置的,但是有的APP对这方面是特别重要的,例如催收的行业,准确获取借款人的位置,才能不扑空~~

基本上实现的原理其实很简单,前端要做的事情就是每次打开APP的时候获取一下手机当前的位置,或者每隔几分钟就重新获取一次。

注:RN提供的方法只能获取到经纬度,不会直接给你具体的城市或者街道,如果要的话,可以用百度或者高德的逆地理编码接口去转,不过一般前端只是传经纬度给后端,具体后端要拿去做什么操作,就不归前端管了。当然,如果你的APP要显示你的当前城市,你也可以用接口转然后显示出来。

下面是我简单实现的代码:

  componentDidMount() {    // APP启动的时候获取地理位置    this.getPosition();  } /** 获取地理位置(经纬度) */  getPosition = (): void => {    /** 获取地理位置 */    navigator.geolocation.getCurrentPosition(      (position: any) => {        // console.warn('成功:' + JSON.stringify(position));        const positionData: any = position.coords;        // 经度:positionData.longitude        // 纬度:positionData.latitude        // 最后一步 todo:高德 || 百度地图逆地理编码转~~具体就是调个接口把经纬度丢进去就行了      },      (error: any) => {        console.warn('失败:' + JSON.stringify(error.message))      }, {        // 提高精确度,但是获取的速度会慢一点        enableHighAccuracy: true,        // 设置获取超时的时间20秒        timeout: 20000,        // 示应用程序的缓存时间,每次请求都是立即去获取一个全新的对象内容        maximumAge: 1000      }    );  }


链接:http://www.jianshu.com/p/1491cee1b31d