欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react native 獲取地理位置的方法示例

 更新時(shí)間:2018年08月28日 14:24:36   作者:JsLin_  
這篇文章主要介紹了react native 獲取地理位置的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

react native 官網(wǎng)介紹了這個(gè) api Geolocation 但是這個(gè)api只能返回 經(jīng)緯度 所以要把經(jīng)緯度 通過(guò)逆地理位置轉(zhuǎn)義 http://recode.ditu.aliyun.com/jsdoc/geocode_api.html 可通過(guò)這個(gè)阿里的開(kāi)放接口

在 react native 中,我們所用的是react native 自帶的api定位功能,無(wú)需引入第三方j(luò)s。

react native 定位是通過(guò)Geolocation這個(gè)模塊來(lái)實(shí)現(xiàn)的。想了解更多關(guān)于Geolocation的知識(shí)請(qǐng)點(diǎn)擊下面 Geolocation自行了解,這里我們主要將他的幾個(gè)方法。

static getCurrentPosition(geo_success, geo_error?, geo_options?)
Invokes the success callback once with the latest location info. Supported options: timeout (ms), maximumAge (ms), enableHighAccuracy (bool) On Android, this can return almost immediately if the location is cached or request an update, which might take a while.

static watchPosition(success, error?, options?)
Invokes the success callback whenever the location changes. Supported options: timeout (ms), maximumAge (ms), enableHighAccuracy (bool), distanceFilter(m)

static clearWatch(watchID)

第一個(gè)方法是獲取第一次定位時(shí)的位置信息,第一個(gè)為成功時(shí)的回掉函數(shù),還有error時(shí)的回掉,第三個(gè)是傳狀態(tài)的。
在請(qǐng)求成功函數(shù)中有以下屬性:

  • 經(jīng)度 : coords.longitude
  • 緯度 : coords.latitude
  • 準(zhǔn)確度 : coords.accuracy
  • 海拔 : coords.altitude
  • 海拔準(zhǔn)確度 : coords.altitudeAcuracy
  • 行進(jìn)方向 : coords.heading
  • 地面速度 : coords.speed
  • 時(shí)間戳 : new Date(position.timestamp)

在請(qǐng)求失敗函數(shù)中有4種情況(err.code狀態(tài)值):

1為用戶拒絕定位請(qǐng)問(wèn)
2暫時(shí)獲取不到位置信息
3為請(qǐng)求超時(shí)
4未知錯(cuò)誤

第三個(gè)options是可選參數(shù),屬性如下:

enableHighAccuracy——指示瀏覽器獲取高精度的位置,默認(rèn)為false。當(dāng)開(kāi)啟后,可能沒(méi)有任何影響,也可能使瀏覽器花費(fèi)更長(zhǎng)的時(shí)間獲取更精確的位置數(shù)據(jù)。

timeout——指定獲取地理位置的超時(shí)時(shí)間,默認(rèn)不限時(shí)。單位為毫秒。

maximumAge——最長(zhǎng)有效期,在重復(fù)獲取地理位置時(shí),此參數(shù)指定多久再次獲取位置。默認(rèn)為0,表示瀏覽器需要立刻重新計(jì)算位置。

static watchPosition(success, error?, options?) 

是多次改變了位置信息時(shí)才會(huì)觸發(fā),一般觸發(fā)的可能性可能用戶多次刷新數(shù)據(jù),如一個(gè)人行車(chē)到其他城市,這時(shí)如果設(shè)置一個(gè)監(jiān)聽(tīng)函數(shù),只要watchid不一樣,就會(huì)不斷的觸發(fā)

由于可能會(huì)出現(xiàn)緩存的情況,所以Geolocation 為我們提供了一個(gè)可以清除緩存的方法watchPosition(),改方法是 用于上一次的定位信息進(jìn)行清除的。

對(duì)了,要啟動(dòng)react native 的定位功能的話,如果你是android 用戶,你需要先在AndroidManifest.xml中加入以下權(quán)限

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

具體實(shí)現(xiàn)

import Geolocation from 'Geolocation';

  ......

 getlocal() {
  Geolocation.getCurrentPosition(
   val => {
    let ValInfo =
     '速度:' +
     val.coords.speed +
     '\n經(jīng)度:' +
     val.coords.longitude +
     '\n緯度:' +
     val.coords.latitude +
     '\n準(zhǔn)確度:' +
     val.coords.accuracy +
     '\n行進(jìn)方向:' +
     val.coords.heading +
     '\n海拔:' +
     val.coords.altitude +
     '\n海拔準(zhǔn)確度:' +
     val.coords.altitudeAccuracy +
     '\n時(shí)間戳:' +
     val.timestamp;
    this.setState({ LocalPosition: ValInfo });
    console.log("打印地理位置:"+`${val.coords.longitude},${val.coords.latitude}`)
    GET_GPRS({
     "l":`${val.coords.latitude},${val.coords.longitude}`,
     "type":111,
    }).then(res => {
     console.log(JSON.stringify(res))
    })
   },
   val => {
    let ValInfo = '獲取坐標(biāo)失敗:' + val;
    this.setState({ LocalPosition: ValInfo }); //如果為空的話 沒(méi)允許開(kāi)啟定位服務(wù)

   },
  );
 }

這里的 GET_GPRS 是自己封裝的 fech請(qǐng)求

記得開(kāi)啟 位置訪問(wèn)權(quán)限

打印結(jié)果如下:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • react反向代理使用http-proxy-middleware問(wèn)題

    react反向代理使用http-proxy-middleware問(wèn)題

    這篇文章主要介紹了react反向代理使用http-proxy-middleware問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 詳解React中Props的淺對(duì)比

    詳解React中Props的淺對(duì)比

    這篇文章主要介紹了React中Props的淺對(duì)比的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-05-05
  • 通過(guò)示例講解Remix?設(shè)計(jì)哲學(xué)理念

    通過(guò)示例講解Remix?設(shè)計(jì)哲學(xué)理念

    這篇文章主要為大家通過(guò)示例講解了Remix?設(shè)計(jì)哲學(xué)理念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • React?中的?JS?報(bào)錯(cuò)及容錯(cuò)方案

    React?中的?JS?報(bào)錯(cuò)及容錯(cuò)方案

    這篇文章主要為大家介紹了React?中的?JS?報(bào)錯(cuò)及容錯(cuò)方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • React元素與組件的區(qū)別示例詳解

    React元素與組件的區(qū)別示例詳解

    這篇文章主要為大家介紹了React元素與組件的區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • react中實(shí)現(xiàn)拖拽排序react-dnd功能

    react中實(shí)現(xiàn)拖拽排序react-dnd功能

    這篇文章主要介紹了react中實(shí)現(xiàn)拖拽排序react-dnd功能,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • React三大屬性之Refs的使用詳解

    React三大屬性之Refs的使用詳解

    這篇文章主要介紹了React三大屬性之Refs的使用詳解,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-04-04
  • React 狀態(tài)的不變性實(shí)例詳解

    React 狀態(tài)的不變性實(shí)例詳解

    這篇文章主要為大家介紹了React 狀態(tài)的不變性實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • JavaScript中React面向組件編程(上)

    JavaScript中React面向組件編程(上)

    本文主要介紹了React組件中默認(rèn)封裝了很多屬性,有的是提供給開(kāi)發(fā)者操作的,其中有三個(gè)屬性非常重要:state、props、refs。感興趣的小伙伴可以參考閱讀
    2023-03-03
  • React中的setState使用細(xì)節(jié)和原理解析(最新推薦)

    React中的setState使用細(xì)節(jié)和原理解析(最新推薦)

    這篇文章主要介紹了React中的setState使用細(xì)節(jié)和原理解析(最新推薦),前面我們有使用過(guò)setState的基本使用, 接下來(lái)我們對(duì)setState使用進(jìn)行詳細(xì)的介紹,需要的朋友可以參考下
    2022-12-12

最新評(píng)論