经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
微信小程序API—获取定位的详解
来源:jb51  时间:2019/4/30 12:15:53  对本文有异议

在微信小程序中,我们可以很方便的通过API接口来获取我们当前的位置,接下来我讲告诉大家微信获取定位的API—wx.getLocation的用法,以及我们通过获取定位,得到当地的位置,天气等信息。

  1. <view class='content'>
  2. <view class='today'>
  3. <view class='info'>
  4. <view class='temp'>{{weather.temperature.data}}℃</view>
  5. <view class='weather'>{{weather.weather.data}} {{weather.winddirection.data}} {{weather.windpower.data}}</view>
  6. <view>友情提示:今天天气不错,是风和日丽的,适合出去玩</view>
  7. <view class='city'>{{weather.city.data}}</view>
  8. </view>
  9. </view>
  10. </view>

首先给出我的前端代码,中括号内的变量就是我们下文中从高德地图返回给我们的json数组中解析出来的。下面让我们来看一下我们如何获得当前的定位以及获取高德地图给我们的信息。

  1. //获取当前位置的经纬度
  2. loadInfo: function(){
  3. var that=this;
  4. wx.getLocation({
  5. type: 'gcj02', //返回可以用于wx.openLocation的经纬度
  6. success: function (res) {
  7. var latitude = res.latitude//维度
  8. var longitude = res.longitude//经度
  9. console.log(res);
  10. that.loadCity(latitude,longitude);
  11. }
  12. })
  13. },

其实获取定位很简单,我们直接调用微信的接口wx.getLocation,结果会返回给我们一个json数组,结果就像上图一样,数组中包含各种属性,我们最需要的就是经度(longitude)和纬度(latitude),我们获得了当前位置的经纬度就可以调用高德地图的API,把我们的经纬度传上去,之后就能够获得高德地图给我们返回的信息。

首先我们需要从高德地图的官网上下载一个微信小程序SDK
http://lbs.amap.com/api/wx/download
在创建的项目中,新建一个名为 libs 目录,将 amap-wx.js (amap-wx.js 从下载的 zip 文件解压后得到)文件拷贝到 libs 的本地目录下,如下图所示。

 

接下来我们需要在页面的js文件中配置我们需要操作的数据

  1. var amapFile = require('../../libs/amap-wx.js');
  2. var markersData = {
  3. latitude: '',//纬度
  4. longitude: '',//经度
  5. key: "需要去高德地图注册成为开发者,然后就会获得一个key"//申请的高德地图key
  6. };

好了,我们配置好外部文件以后,就可以在js里面写逻辑了,下面贴出我的js代码。

  1. var amapFile = require('../../libs/amap-wx.js');
  2. var markersData = {
  3. latitude: '',//纬度
  4. longitude: '',//经度
  5. key: "高德地图key"//申请的高德地图key
  6. };
  7. Page({
  8.  
  9. /**
  10. * 页面的初始数据
  11. */
  12. data: {
  13. weather:[],
  14. },
  15.  
  16. /**
  17. * 生命周期函数--监听页面加载
  18. */
  19. onLoad: function (options) {
  20. this.loadInfo();
  21. },
  22.  
  23.  
  24. //获取当前位置的经纬度
  25. loadInfo: function(){
  26. var that=this;
  27. wx.getLocation({
  28. type: 'gcj02', //返回可以用于wx.openLocation的经纬度
  29. success: function (res) {
  30. var latitude = res.latitude//维度
  31. var longitude = res.longitude//经度
  32. console.log(res);
  33. that.loadCity(latitude,longitude);
  34. }
  35. })
  36. },
  37.  
  38. //把当前位置的经纬度传给高德地图,调用高德API获取当前地理位置,天气情况等信息
  39. loadCity: function (latitude, longitude){
  40. var that=this;
  41. var myAmapFun = new amapFile.AMapWX({ key: markersData.key });
  42. myAmapFun.getRegeo({
  43. location: '' + longitude + ',' + latitude + '',//location的格式为'经度,纬度'
  44. success: function (data) {
  45. console.log(data);
  46. },
  47. fail: function (info) { }
  48. });
  49.  
  50. myAmapFun.getWeather({
  51. success: function (data) {
  52. that.setData({
  53. weather: data
  54. })
  55. console.log(data);
  56. //成功回调
  57. },
  58. fail: function (info) {
  59. //失败回调
  60. console.log(info)
  61. }
  62. })
  63. },
  64.  
  65.  
  66. })

我们在onload函数中获取当前的定位,我们把经纬度信息传递给myAmapFun.getRegeo方法中的location参数,接下来我们可以看看高德地图给我们返回的信息。

我们获取了我们的位置以及邮政编码等一系列信息,大家可以去高德地图上注册一个开发者,得到一个key,然后测试一下,也可以获得你们当地的信息。

我们再看一下myAmapFun.getWeather给我们返回的天气信息。

我们顺利得到了我们当地的天气信息,然后再把这些信息显示在我们的wxml界面就行了,大家注意一下图片中的属性,然后再看一下wxml中括号内的变量,就可以知道讲json数组的某些属性的值如何传到前端了。有一个细节就是我把myAmapFun.getWeather方法返回的data数组传给了我在全局data中定义的weather数组,这样我们在前端就可以通过上文wxml中的方法来显示数组中的值。

文章的末尾还是要强调一下,本次测试需要开发者自己去高德地图官网注册开发者账号,然后获取自己的key,并且需要下载高德地图提供给我们的微信小程序SDK,接着在项目中配置解压后的js文件,最后我们就可以像上文那样去使用高德地图的接口了。

以上所述是小编给大家介绍的微信小程序API获取定位详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对w3xue网站的支持!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号