作者:知晓云 - 小程序开发快人一步
来源:知晓课堂
在上一节,我们已经简单地完成一个天气查询小程序的静态页面,现在,我们就来为它加上逻辑代码。
获取当前位置天气
想象一下,当小程序加载,默认进入天气详情页面,此时页面初始化时应该做哪些工作呢?
初始化逻辑分3步走,具体如下:
1. 首先获取当前地理位置信息,取得经纬度。
2. 调用腾讯地理位置逆解析服务,获取当前位置信息。
3. 调用心知天气 API,获取当前城市天气。
首先我们需要获取当前地理位置信息。小程序提供了 wx.getLocation API,可以让我们有能力获取到当前使用者的地理位置信息。
wx.getLocation 使用方法如下:
wx.getLocation({
success: function (res) { // success 属性是获取成功回调函数
console.log(res)
that.setData({
hasLocation: true,
location: formatLocation(res.longitude, res.latitude)
})
}
})
我解释一下上述语句:我们给 wx.getLocation 函数传递了一个对象,对象中有 success 属性,该属性为一个 Function 类型,用于绑定获取地理位置成功事件的回调,在这个回调事件中,我们可以拿到一个 res 对象,res 对象包含 longitude 和 latitude,分别是经度、纬度。
接下来我们要通过经纬度获取城市信息,这里我们使用地理位置逆解析服务,使用前需要在腾讯地图注册,申请 API,然后请求 http://apis.map.qq.com/ws/geocoder/v1/?location=,取得当前城市信息。
发起请求的代码如下:
wx.request({
url: 'http://apis.map.qq.com/ws/geocoder/v1/',
data: {
location: '39.984154,116.307490'
},
success: function(result) {
// ...
},
fail: function({errMsg}) {
// ...
}
})
我们使用 wx.request API,这个 API 让我们拥有发起网络请求的能力,这样我们就可以通过访问腾讯地图提供的 restful API 来解析经纬度数据了。
下面是参数说明:
l url:小程序请求 URL
l data :query 参数,location 为经纬度信息
l success:成功回调
l fail:失败回调
在成功回调中我们可以,接下来就可以根据城市来获取天气信息了,调用心知天气 API 前同样需要在心知天气注册并申请 API KEY。
我们依然使用 wx.request API
wx.request({
url: 'https://api.seniverse.com/v3/weather/now.json',
data: {
key: 'API_KEY',
location: '北京'
},
success: function(result) {
// ...
},
fail: function({errMsg}) {
// ...
}
}}
接下来我们继续开发地图页面,我们使用 map 组件,这个组件可以在页面上创建一个可交互的地图。
根据地图获取天气信息
页面结构搭建完毕后,我们开始编写页面逻辑。 这个页面的重点在于初始化 map 组件,主要有两步:
1. 创建 map 组件并显示。
2. 在 map 组件上创建每个城市的标记点。
在 demo 中提供了全国省会城市的经纬度信息,在地图页面 目录下,名称为 loc.js,城市经纬度信息结构如下:
{
name:'广州市', // 城市名称
latlng:'113.264385,23.129112' // 对应的城市经纬度信息
}
然后我们在map.js引入该文件,将其转换成 marker数组,用于在页面上显示标记:
const locData = require('./loc.js')
var markers = locData.map(loc=>{
let latlng = loc.latlng.split(',') // 经纬度信息原本是以字符串形式保存,这里要将其分割成2部分
return {
id: loc.name,
latitude: parseFloat(latlng[1]), // 经纬度信息需要转换成数值型
longitude: parseFloat(latlng[0]),// 经纬度信息需要转换成数值型
name: loc.name,
iconPath:'/image/location.png',
}
})
当用户点击 marker,我们可以用 wx.switchTab API 导航到天气详情页,并带上城市信息,这里由于 switchTab API 的限制,无法在 URL 中传递参数,因此我们在全局对象 app 上设置 currentCity 属性来保存当前选中城市。
var app = getApp()
app.globalData.currentCity = e.markerId
wx.switchTab({
url: '/page/index/index',
})
我们回到天气详情页面,我们需要在 index.js 做下修改,当页面载入时,判断是否有指定城市,如果有则获取指定城市的天气信息
onShow: function(option){
this.reloadData()
}
map.js完整代码如下:
const locData = require('./loc.js')
var markers = locData.map(loc=>{
let latlng = loc.latlng.split(',')
return {
id: loc.name,
latitude: parseFloat(latlng[1]),
longitude: parseFloat(latlng[0]),
name: loc.name,
iconPath:'/image/location.png',
}
})
Page({
data: {
latitude: markers[0].latitude,
longitude: markers[0].longitude,
markers: markers,
},
switchCity(e){
//console.log(e)
var app = getApp()
app.globalData.currentCity = e.markerId
wx.switchTab({
url: '/page/index/index',
})
}
})
至此,我们就完成了一个天气查询的小程序了。
相关阅读
第一章:一文了解小程序
第六章:小程序多媒体相关能力
第七章:在小程序里查询天气(上)
关注「知晓云」公众号,点击菜单栏「知晓云」-「知晓课堂」,获取更多开发教程。
