小程序中免费接入和风天气api

前言

最近项目中遇到天气预报展示的功能需求,调研后最终选择接入和风天气api,功能亮点如下:

  • 非商业用户 1000次/天 到 SDK 无限量访问
  • 按坐标、城市名称、格点方式定位并展示对应天气信息
  • 实时、三日、七日天气预报
  • 灾害极端天气预警信息
  • 全国空气质量信息
  • 热带台风信息
  • 天文气象数据(日出、日落、月相、太阳角度等)

订阅模式

有三种订阅模式:

  • 免费订阅
  • 标准订阅
  • 高级订阅

对比如下

大家可以根据自己需求接入对应的模式即可,下面笔者接入的是免费订阅。

接入

首先我们需要注册并登录和风天气管理端(地址),然后创建项目获取到key

获取近7日天气预报

拿到key之后,调用接口就很简单了。这里举个功能使用例子,如获取近7天天气预报:

bash 复制代码
https://api.qweather.com/v7/weather/7d?[请求参数]

请求参数包括必选和可选参数,参数之间使用&进行分隔。

更详细信息可以直接查阅文档-> 传送门

使用天气图标

接下来讲解下如何在小程序中引入并使用天气图标。

我们先打开下天气图标下载官网->传送门

接着点击下载,将图标文件下载到本地,解压后我们只需用到两个文件:

接着在页面中引入这两个文件:

xml 复制代码
<style>
@import './static/font/qweather-icons.css';

@font-face {
  font-family: 'qweather-icons';
  src: url('./static/font/qweather-icons.ttf')
    format('truetype');
}

.QWeather {
  font-family: 'qweather-icons';
  font-size: 20px;
}
</style>

接着打开qweather-icons.css文件,我们将第一部分默认引入字体代码路径去掉(上面已经引入过了)

页面中使用

arduino 复制代码
 <text class="QWeather"
        :class="[isNight ? 'qi-' + item.iconNight : 'qi-' + item.iconDay]"
 ></text>

这里需要注意的是:

  • 接口返回的图标字段没有qi字段,我们需要在类名中加上前缀【qi-】。
  • 返回的图标分白天跟晚上,我们需要判断下当前时间是白天还是晚上,然后分别取iconDay和iconNight字段

看下效果吧

扫码体验

评论区可扫码体验哦~

相关推荐
吃饺子不吃馅8 小时前
了解微前端:为何 Web Component 是绕不开的关键技术?
前端·javascript·架构
恋猫de小郭8 小时前
第一台 Andriod XR 设备发布,Jetpack Compose XR 有什么不同?对原生开发有何影响?
android·前端·flutter
muyouking118 小时前
Tailwind CSS 小白快速入门速查手册
前端·css·css3
社恐的下水道蟑螂9 小时前
用 n8n 打造 AI 科技新闻速览工作流:自动化获取、总结,每天高效充电
前端
陈随易9 小时前
PaddleOCR-VL可太强了,图片识别转文字的巅峰之作
前端·后端·程序员
盗德9 小时前
紧急项目下,前端是“先乱炖”还是“慢火煲汤”?我选第三条路
前端·程序员
zmirror9 小时前
Monorepo单仓多包&独立部署
前端
Linsk9 小时前
为什么BigInt无法通过Babel降级?
前端·typescript·前端工程化
Asort9 小时前
JavaScript设计模式(十八)——备忘录模式:状态保存与恢复的艺术
前端·javascript·设计模式