获取腾讯天气数据(jsonp 方式)

本文档介绍了如何通过JSONP技术跨域获取腾讯天气API的数据,特别是48小时内的天气预报。文章详细解析了请求参数,如`source`、`weather_type`、`province`和`city`,并展示了如何使用JavaScript处理响应数据,包括格式化时间以适应页面展示。同时,提供了HTML模板和JavaScript代码示例,最终在网页上呈现友好的天气信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

利用 jsonp 方式获取腾讯天气数据

案例分析

下面是利用 jsonp 函数写的一个小案例:跨域请求腾讯天气数据并展示在自己的页面。腾讯天气网站的中我们需要获取的数据是两天(48)内的天气数据,其他的我们不需要。即需要下图(网址:https://tianqi.qq.com/index.htm)中的数据。

在这里插入图片描述

查看网页中的请求信息发现一共有 4 个请求是利用 jsonp 实现的跨域请求(请求参数带有 callback 参数且请求地址是非同源的)。其中有三个是从 https://wis.qq.com/weather/common 得到一些有关天气的数据,有一个是从 https://apis.map.qq.com/ws/location/v1/ip 获取一些和定位有关的数据。当然我们只需要看一个请求 48 小时的天气数据的 jsonp 请求,打开如下(有下划线的那个请求):

在这里插入图片描述返回的数据的详细信息如下图:

在这里插入图片描述
如果没有接口文件(我也没有),为了可以更加清晰地了解请求需要传递地参数和响应数据的详细信息可以在另一个页面打开该请求。可以发现请求信息好长。。。

https://wis.qq.com/weather/common?source=pc&weather_type=observe%7Cforecast_1h%7Cforecast_24h%7Cindex%7Calarm%7Climit%7Ctips%7Crise&province=%E5%B9%BF%E4%B8%9C%E7%9C%81&city=%E5%B9%BF%E5%B7%9E%E5%B8%82&county=&callback=jQuery111307981370712135891_1618987774109&_=1618987774111

而且看起来好乱,为此我利用 encodeURL() 对其进行解码结果如下

https://wis.qq.com/weather/common?source=pc&weather_type=observe|forecast_1h|forecast_24h|index|alarm|limit|tips|rise&province=广东省&city=广州市&county=&callback=jQuery111307981370712135891_1618987774109&_=1618987774111

现在可以根据请求地址信息看看其请求参数的信息:

  • source:设备类型。
  • weather_type:需要获取哪些天气数据,这里我们需要获取的是 forecast_1h|forecast_24h 。
  • province:需要获取哪个省份的天气数据。
  • city:需要获取的是哪个城市的天气数据。
  • callback:jsonp 的响应处理函数。

上面的设备类型应该是由浏览器进行判断输入,省份城市应该是由另一个定位有关的跨域请求得到。但是我们这里自己手动传入即可。

代码实现

如果将得到的数据直接渲染至页面可以发现有关时间的数据的展示太不友好了,所以需要封装一个格式化时间的方法。并将方法导入模板中对时间数据进行必要的格式化操作。

在这里插入图片描述

<body>
    <div class="container">
        <table class="table" align="center" id="box"></table>
    </div>
    <script src="/js/template-web.js"></script>
    <script src="/js/jsonp.js"></script>
    <!-- 渲染模板准备 -->
    <script id="tpl" type="taxt/html">
        <tr>
            <th>时间</th>
            <th>温度</th>
            <th>天气</th>
            <th>风向</th>
            <th>风力</th>
        </tr>
        {{each info}}
        <tr>
            <td style="width:200px">{{dateFormat($value.update_time)}}</td>
            <td>{{$value.degree}}</td>
            <td>{{$value.weather}}</td>
            <td>{{$value.wind_direction}}</td>
            <td>{{$value.wind_power}}</td>
        </tr>
        {{/each}}
    </script>
    <script>
        // 获取table标签
        var box = document.getElementById('box');
        function dateFormat(date) {
            var year = date.substr(0, 4);
            var month = date.substr(4, 2);
            var day = date.substr(6, 2);
            var hour = date.substr(8, 2);
            return year + '年' + month + '月' + day + '日' + hour + '时';
        }
        // 向模板中开放外部变量
        template.defaults.imports.dateFormat = dateFormat;
        jsonp({
            url: 'https://wis.qq.com/weather/common',
            data: {
                source: 'pc',
                weather_type: 'forecast_1h',
                // weather_type: 'forecast_1h|forecast_24h',
                province: '黑龙江省',
                city: '哈尔滨市'
            },
            success: function(data) {
                var html = template('tpl', {
                    info: data.data.forecast_1h
                });
                box.innerHTML = html;
            }
        })
    </script>
</body>

最后的页面展示如下图:

在这里插入图片描述

### 微信小程序获取当前位置坐标并调用天气 API 的实现 #### 实现概述 在微信小程序中,可以通过 `wx.getLocation` 接口获取用户的经纬度信息[^1]。随后利用这些经纬度数据通过第三方天气服务提供商(如腾讯云、阿里云或其他开放平台)提供的天气 API 查询对应地区的实时天气情况。 以下是具体的技术细节和代码示例: --- #### 获取用户地理位置的实现方法 使用 `wx.getLocation` 方法来获取用户的地理坐标(纬度和经度)。此接口返回的数据可以直接用于后续的地图定位或者逆向解析为具体的地址名称[^3]。 ```javascript // app.js 或者 page.js 中定义的方法 getLocation() { wx.getLocation({ type: 'gcj02', // 返回可以用于微信内置地图的坐标 success(res) { const latitude = res.latitude; const longitude = res.longitude; console.log('Latitude:', latitude, ', Longitude:', longitude); // 将经纬度传递给其他函数处理 getWeatherByLocation(latitude, longitude); }, fail(err) { console.error('Failed to get location:', err); } }); } ``` 上述代码片段展示了如何通过 `wx.getLocation` 来捕获用户的 GPS 数据,并将其作为输入参数传入到另一个自定义函数 `getWeatherByLocation()` 中进一步操作。 --- #### 使用逆地理编码将经纬度转为实际地址 如果希望展示更友好的界面提示,则还需要把原始的经纬度转化为人类可理解的城市名或街道级描述[^2]。这一步通常依赖于高德地图、百度地图或者其他支持此类功能的服务商所提供的 RESTful Web Service 完成转换过程。 下面是一个简单的例子演示怎样发送 HTTP 请求至某特定服务商完成这一任务: ```javascript reverseGeocode(lat, lng){ let url = `https://restapi.amap.com/v3/geocode/regeo?key=YOUR_API_KEY&location=${lng},${lat}`; wx.request({ url:url, method:'GET', header:{'content-type':'application/json'}, success:function(responseData){ var addressComponent=responseData.data.regeocode.addressComponent; console.log(`Current Position:${addressComponent.province}-${addressComponent.city}-${addressComponent.district}`); }, error:function(errorInfo){ console.warn("Error occurred during reverse geocoding",errorInfo); } }); } ``` 注意替换其中占位符 YOUR_API_KEY 成为你自己的开发者密钥才能正常使用该服务。 --- #### 调用天气预报 API 并显示结果 最后一步就是联系外部气象服务平台请求最新的气候状况更新。这里假设采用的是一个假想的支持 JSONP 格式的公共端点为例说明整个流程逻辑如下所示 : ```javascript function getWeatherByLocation(lat, lon){ const weatherUrl=`http://t.weather.sojson.com/api/weather/city/101010100?latitude=${lat}&longitude=${lon}`; wx.request({ url :weatherUrl , data :{} , header:{ "Content-Type":"application/x-www-form-urlencoded" }, success :(res)=>{ if (res.statusCode===200 && !res.errMsg ){ displayWeatherDetails(res.result.today.wea,res.result.temperature.now.tempC ); }else{ alertUserFailureToFetchWeather(); } }, failure:(err)=>{console.debug(err);} }) } displayWeatherDetails=(condition,temp)=>{ document.getElementById("currentCondition").innerText="Today's Condition:"+ condition ; document.getElementById("temperatureValue").innerText="Temperature is "+ temp +"° Celsius"; } alertUserFailureToFetchWeather=()=>{ wx.showToast({title:"Unable To Fetch Weather Data!",icon:"none"}); } ``` 以上脚本段落解释了当成功接收到服务器响应包之后应该采取哪些行动步骤去渲染 UI 组件上的文字标签内容;同时也包含了错误情形下的反馈机制设计思路供参考学习之用。 --- ### 注意事项 - **权限声明**: 需要在项目的 manifest 文件里添加必要的隐私政策同意条款告知最终使用者会收集其所在区域的相关资料以便提供更好的用户体验效果。 - **频率限制**: 大部分在线资源都有严格的访问次数上限规定,请务必查阅官方文档了解清楚后再合理安排好程序架构布局以免超出限额遭到封禁处罚风险。 - **安全性考量**: 对敏感个人信息做好加密保护措施防止泄露出去造成不必要的麻烦纠纷等问题发生几率最小化为目标努力前行不断优化改进现有解决方案直至达到理想状态为止! ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值