ReactNative升级篇(四):地图定位TypeError:undefined is not an object navigator.geolocation.getCurrentPosition

因项目需求需要再次做RN升级,从最开始的0.48升级到0.57稳定后,一直持续项目开发,然后到现在的0.62.2版本;RN也做了重大调整,许多核心组件已不能直接使用;例如 前面上文提到的ListView、WebView、ART等核心组件,还有文中即将提到的地图定位geolocation组件已经不能直接使用了;

未升级之前的定位组件是不需要import导入的,都是直接访问全局的navigator.geolocation对象;

现在升级到0.6版本之后,会提示报如下错误:

凡事不要慌,直接看下错误信息,已经指出具体报错信息,navigator.geolocation.getCurrentPosition找不到了

05aaab42c482a7e6101a0e3b122a69dc.png

错误信息看完了,现在我们就直接上解决方案:

在package.json引入@react-native-community/geolocation插件,

1、执行npm install --save @react-native-community/geolocation

2、方案一:需要进行link,但有可能会link失败,可以手动进行添加

3、方案二:手动进行配置Androidstudio配置文件:

@1、settings.gradle中添加

include ':@react-native-community_geolocation' project(':@react-native-community_geolocation').projectDir = new File(rootProject.projectDir, '../node_modules/@react-native-community/geolocation/android')

@2、主module中导入:

compile project(path: ':@react-native-community_geolocation')

@3、

Application中在getPackages方法中新增
new GeolocationPackage()

编译运行!地理定位组件就到这里了,遇到其他错误信息再一一进行上传,欢迎讨论!

博客链接:https://blog.csdn.net/IT_luntan/article/details/108616335

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐