小程序中免费接入和风天气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字段

看下效果吧

扫码体验

评论区可扫码体验哦~

相关推荐
恋猫de小郭19 分钟前
对于普通程序员来说 AI 是什么?AI 究竟用的是什么?
前端·flutter·ai编程
大怪v37 分钟前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
我是天龙_绍39 分钟前
vue3 props 如何写ts,进行类型标注
前端
叫我詹躲躲1 小时前
n8n 自动化工作流平台完整部署
前端·langchain·领域驱动设计
遂心_2 小时前
为什么 '1'.toString() 可以调用?深入理解 JavaScript 包装对象机制
前端·javascript
IT_陈寒2 小时前
JavaScript 性能优化:5 个被低估的 V8 引擎技巧让你的代码快 200%
前端·人工智能·后端
岛风风3 小时前
关于手机的设备信息
前端
ReturnTrue8683 小时前
nginx性能优化之Gzip
前端
w_y_fan4 小时前
Flutter 滚动组件总结
前端·flutter
wuli金居哇4 小时前
我用 Turborepo 搭了个 Monorepo 脚手架,开发体验直接起飞!
前端