前言
最近在學(xué)小程序開(kāi)發(fā),剛好學(xué)到天氣預(yù)報(bào)功能的制作,于是給大家分享下。
效果圖


天氣API獲取
這里我用的是和風(fēng)天氣的API,打開(kāi)官網(wǎng)注冊(cè)或者登陸你的賬號(hào)
進(jìn)入控制臺(tái),新建應(yīng)用
這是剛剛我們創(chuàng)建好的應(yīng)用,點(diǎn)擊添加KEY
選擇WebAPI
這注冊(cè)好我們的API了
微信小程序后臺(tái)域名配置
登陸小程序后臺(tái),分別點(diǎn)擊開(kāi)發(fā)和開(kāi)發(fā)設(shè)置
點(diǎn)擊修改,將我們API的域名添加到request合法域名里面https://free-api.heweather.net
頁(yè)面代碼
.wxml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
< view class = "header" > < view class = "top" > < view class = "city" > {{city}} </ view > < view class = "search" > < input placeholder = "輸入城市名" bindinput = "bindKeyInput" placeholder-style = "color:white" ></ input > < view class = "bt_search" bindtap = "search" > < icon type = "search" size = "18" color = "white" ></ icon > </ view > </ view > </ view > < view class = "center" > < view class = "tmp" > {{tmp}}° </ view > < image mode = "widthFix" class = "cond-image" src = "https://moyv.top/wechat/images/weather/{{imgsrc}}.png" > </ image > </ view > < view class = "bottom" > < view >{{wind_dir}} {{wind_sc}}級(jí)</ view > < view >濕度 {{hum}}%</ view > < view >氣壓 {{pres}}Pa</ view > </ view > </ view > < view class = "container" > < view class = "hourly_title" >24小時(shí)預(yù)報(bào)</ view > < scroll-view scroll-x = "true" class = "hourly" > < view class = "h_item" wx:for = "{{hourly}}" wx:key = "index" > < text class = "h_time" >{{item.time}}</ text > < view class = "h_img" > < image mode = "widthFix" src = "https://moyv.top/wechat/images/weather/{{item.imgsrc}}.png" ></ image > </ view > < text class = "h_tmp" >{{item.tmp}}°</ text > < text class = "h_wind_dir" >{{item.wind_dir}}</ text > < text class = "h_wind_sc" >{{item.wind_sc}}級(jí)</ text > </ view > </ scroll-view > < view class = "hourly_title" >7天預(yù)報(bào)</ view > < scroll-view scroll-x = "true" class = "daily" > < view class = "d_item" wx:for = "{{daily_forecast}}" wx:key = "index" > < text class = "d_txt" >{{item.d_txt}}</ text > < text class = "d_date" >{{item.d_date}}</ text > < view class = "h_img" > < image mode = "widthFix" src = "https://moyv.top/wechat/images/weather/{{item.imgsrc_d}}.png" ></ image > </ view > < text class = "h_tmp" >{{item.tmp_min}}°~{{item.tmp_max}}°</ text > < view class = "h_img" > < image mode = "widthFix" src = "https://moyv.top/wechat/images/weather/{{item.imgsrc_n}}.png" ></ image > </ view > < text class = "d_wind_dir" >{{item.wind_dir}}</ text > < text class = "d_wind_sc" >{{item.wind_sc}}級(jí)</ text > </ view > </ scroll-view > </ view > < view class = "footer" > -天氣數(shù)據(jù)來(lái)自和風(fēng)天氣api- </ view > |
.wxss
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
|
page { background-color : #f6f6f6 ; } .header { background-color : #64c8fa ; /* background-image: linear-gradient(to right, #64a0f8, #64c8fa); */ height : 450 rpx; padding-top : 32 rpx; text-align : center ; } . top { display : flex; justify- content : space-between; align- content : center ; align-items: center ; } .city { text-align : center ; color : white ; display : inline- block ; font-size : 52 rpx; margin-left : 32 rpx; } .search { margin-right : 32 rpx; border-radius: 8 rpx; display : inline-flex; justify- content : center ; align- content : center ; align-items: center ; background-color : rgba( 0 , 0 , 0 , 0.1 ); height : 70 rpx; } .search input { width : 200 rpx; padding : 18 rpx 32 rpx; text-align : left ; color : white ; display : inline- block ; } .bt_search { border-radius: 0 8 rpx 8 rpx 0 ; height : 100% ; background-color : rgba( 0 , 0 , 0 , 0.1 ); display : inline-flex; justify- content : center ; align- content : center ; align-items: center ; } .bt_search icon { margin : 8 rpx 18 rpx; } . center { display : flex; justify- content : space-between; align- content : center ; align-items: center ; } .tmp { margin-left : 18 rpx; display : inline- block ; font-size : 180 rpx; color : white ; } .cond-image{ width : 200 rpx; margin-right : 32 rpx; margin-top : 32 rpx; } . bottom { display : flex; justify- content : space-between; align- content : center ; align-items: center ; } . bottom view{ color : white ; margin : 32 rpx; } .hourly_title{ font-weight : bold ; font-size : 42 rpx; padding : 18 rpx 32 rpx; } .hourly { width : 718 rpx; margin : 0 18 rpx; border-radius: 18 rpx; box-shadow: 0.1 rem 0.1 rem 0.5 rem rgba( 0 , 0 , 0 , 0.15 ); white-space : nowrap ; background-color : white ; } .h_item { margin : 18 rpx 0 ; display : inline- block ; width : 143.5 rpx; text-align : center ; font-size : 28 rpx; } .h_img { margin : 64 rpx 0 ; } .h_img image { width : 60 rpx; } .h_item text { display : block ; } .h_time { color : gray ; } .h_wind_dir { margin-top : 32 rpx; } .h_wind_sc { color : gray ; } .h_tmp { color : #027aff ; } .daily { width : 718 rpx; white-space : nowrap ; margin : 0 18 rpx; background-color : white ; border-radius: 18 rpx; box-shadow: 0.1 rem 0.1 rem 0.5 rem rgba( 0 , 0 , 0 , 0.15 ); } .d_item { margin : 18 rpx 0 ; display : inline- block ; width : 179.5 rpx; text-align : center ; font-size : 28 rpx; } .d_item text { display : block ; } .d_date { color : gray ; } .d_wind_dir { margin-top : 32 rpx; } .d_wind_sc { color : gray ; } .footer{ font-size : 28 rpx; color : gray ; text-align : center ; margin-top : 50 rpx; margin-bottom : 18 rpx; } |
.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
Page({ /** * 頁(yè)面的初始數(shù)據(jù) */ data: { search_city: '' , imgsrc:100 }, /** * 根據(jù)城市獲取天氣預(yù)報(bào) */ getWeather(city) { let that = this //獲取實(shí)況天氣 wx.request({ url: 'https://free-api.heweather.net/s6/weather/now?key=你后臺(tái)的key&location=' + city, success: function (res) { if (res.data.HeWeather6[0].status == 'unknown location' ) { wx.showToast({ title: '抱歉!沒(méi)有該城市的天氣預(yù)報(bào)' , icon: 'none' , duration: 2000 }) return ; } console.log(res) that.setData({ city: city, tmp: res.data.HeWeather6[0].now.tmp, imgsrc: res.data.HeWeather6[0].now.cond_code, wind_dir: res.data.HeWeather6[0].now.wind_dir, wind_sc: res.data.HeWeather6[0].now.wind_sc, hum: res.data.HeWeather6[0].now.hum, pres: res.data.HeWeather6[0].now.pres }) //獲取24小時(shí)天氣預(yù)報(bào) wx.request({ url: 'https://free-api.heweather.net/s6/weather/hourly?key=你后臺(tái)的key&location=' + city, success: function (res) { var arr = res.data.HeWeather6[0].hourly var hourly = [] for ( var i = 0; i < arr.length; i++) { hourly[i] = { "imgsrc" : arr[i].cond_code, "tmp" : arr[i].tmp, "time" : arr[i].time.substring(11), "wind_dir" : arr[i].wind_dir, "wind_sc" : arr[i].wind_sc } } that.setData({ hourly: hourly }) var weekArray = new Array( "周日" , "周一" , "周二" , "周三" , "周四" , "周五" , "周六" ); //獲取未來(lái)7天天氣預(yù)報(bào) wx.request({ url: 'https://free-api.heweather.net/s6/weather/forecast?key=你后臺(tái)的key&location=' + city, success: function (result) { //console.log(result) var arr = result.data.HeWeather6[0].daily_forecast var daily_forecast = [] for ( var i = 0; i < arr.length; i++) { daily_forecast[i] = { d_txt: i == 0 ? "今天" : weekArray[ new Date(arr[i].date).getDay()], d_date: arr[i].date.substring(5), imgsrc_d: arr[i].cond_code_d, imgsrc_n: arr[i].cond_code_n, wind_dir: arr[i].wind_dir, wind_sc: arr[i].wind_sc, tmp_max: arr[i].tmp_max, tmp_min: arr[i].tmp_min, cond_txt_d: arr[i].cond_txt_d } } that.setData({ daily_forecast: daily_forecast }) } }) } }) } }) }, bindKeyInput(e) { this .setData({ search_city: e.detail.value }) }, search() { this .getWeather( this .data.search_city) }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載 */ onLoad: function (options) { this .getWeather( "廣州" ) }, }) |
.json
1
2
3
4
|
{ "usingComponents" : {}, "navigationBarTitleText" : "天氣預(yù)報(bào)" } |
注意問(wèn)題(必看)
由于我的項(xiàng)目有用到天氣預(yù)報(bào)的逐小時(shí)預(yù)報(bào)和7天預(yù)報(bào),和風(fēng)天氣又必須實(shí)名才能獲取到此數(shù)據(jù),所以請(qǐng)登錄和風(fēng)天氣后臺(tái)進(jìn)行實(shí)名認(rèn)證
到此這篇關(guān)于微信小程序?qū)崿F(xiàn)天氣預(yù)報(bào)功能(附源碼)的文章就介紹到這了,更多相關(guān)小程序?qū)崿F(xiàn)天氣預(yù)報(bào)內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://blog.csdn.net/weixin_44042074/article/details/105324658