微信小程序-使用高德获取实时天气和天气预报

一、获取实时天气可以完全按照官方步骤操作(点链接可跳转):

1.获取高德的key,获取实时天气数据时需要

2.设置安全通信域名,在小程序中记得刷新    不会设置可以点这里,第五步有写

3.获取实时天气数据,下图为获取到的实时天气报文

二、获取天气预报(高德只提供后三天的预报)

前面的准备步骤和获取实时天气一样,所以下面只放获取的代码。

1.从高德获取到的天气预报报文:

2.index.js中的onload方法下代码:

AMapWX基本方法可参照-->参考手册

此处的var amap = require('../../libs/amap-wx');

var that = this
var myAmapFun = new amap.AMapWX({key:'你申请的高德key'});
myAmapFun.getWeather({
      type:'forecast',//表示获取的是预报信息 默认live(实时天气)
      success: function(data){
        console.log(data)
        //成功回调
        var weatherarr = new Array(3);
        for(var i = 0; i < 3; i++){
          weatherarr[i] = data.forecast.casts[i+1];//获取后三天预报信息 今日的不保存
        }
        that.setData({
          forecast:weatherarr
        })
      },
      fail: function(info){
        //失败回调
        console.log(info)
      }
    });

3.index.wxml下

<!--wx:for默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item-->
<!--此处周一至周日的判断是博主作为一个初学者能想到的办法 如有更好的方法望留言告知 谢谢-->
<view class="wetheritemtr" wx:for="{{forecast}}" wx:key="index" >
	<view class="td" wx:if="{{item.week == 1}}">周一</view>
	<view class="td" wx:if="{{item.week == 2}}">周二</view>
	<view class="td" wx:if="{{item.week == 3}}">周三</view>
    <view class="td" wx:if="{{item.week == 4}}">周四</view>
    <view class="td" wx:if="{{item.week == 5}}">周五</view>
    <view class="td" wx:if="{{item.week == 6}}">周六</view>
    <view class="td" wx:if="{{item.week == 7}}">周日</view>
    <view class="td">天气:{{item.dayweather}}转{{item.nightweather}}</view>
    <view class="td">温度:{{item.daytemp}}℃</view>
    <view class="td">风速:{{item.daywind}} {{item.daypower}}</view>
</view>

4.index.wxss可自行发挥

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值