获取天气信息的方法以及定位获取当前的位置经纬度

1.获取天气的接口需要,市的参数,下面是获取当前省市的位置接口方法

 $.ajax({
        type: "get",//接口规定,只能用get
        async: true,//异步
        url: "https://apis.map.qq.com/ws/location/v1/ip",//接口地址
        data: {"key":"PTMBZ-GCQLW-SC2RG-R2FNI-HWPNQ-4PBQM","output":"jsonp"},//参数格式必须用到output传参为jsonp,否则会报跨域问题
        dataType: "jsonp",//跨域,必须用到jsonp
        success: function(result){
            console.log(JSON.stringify(result));
        },
        error: function (XMLHttpRequest,textStatus,errorThrown){
            console.log(JSON.stringify(XMLHttpRequest));
        }
    });

2.拿到位置后请求获取天气的接口

$.ajax({
            type: 'get', //接口规定,只能用get
            async: true, //异步
            url: 'https://apis.map.qq.com/ws/location/v1/ip', //接口地址
            data: {
                key: 'PTMBZ-GCQLW-SC2RG-R2FNI-HWPNQ-4PBQM',
                output: 'jsonp'
            }, //参数格式必须用到output传参为jsonp,否则会报跨域问题
            dataType: 'jsonp', //跨域,必须用到jsonp
            success: function (res) {
                weather(res.result.ad_info.province,res.result.ad_info.city)
                console.log(res)
            },
            error: function (XMLHttpRequest, textStatus, errorThrown) {
                console.log(XMLHttpRequest)
            }
        })
        // * source: pc  //接口类型pc或者wx
        // * callback: 回调函数 不传直接返回json
        // * weather_type参数(查询类型,多个|分隔):   observe|forecast_1h|forecast_24h|index|alarm|limit|tips|air|rise
        // *   observe 当前天气
        // *   alarm 预警
        // *   tips 天气介绍
        // *   index 穿衣,舒适度等等...
        // *   air 空气质量
        // *   rise 日出
        // *

        function weather(province,city) {
            $.ajax({
                url: 'https://wis.qq.com/weather/common',
                type: 'get',
                data: {
                    source: 'pc',
                    weather_type: 'observe|forecast_1h|forecast_24h|index|alarm|limit|tips|air|rise',
                    province: province,
                    city: city,
                    county: ""
                },
                dataType: 'jsonp',
                success: function (res) {
                    if (res.status == 200 && res.data) {
                        console.log(res)
                    }
                }
            })
        }

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要根据当前位置获取天气信息,你需要使用浏览器的定位功能来获取用户的经纬度,然后将经纬度传递给一个天气 API 接口,获取天气信息。 以下是一个使用 Vue.js 实现这一功能的示例: 首先,你需要使用 HTML5 的 Geolocation API 来获取用户的当前位置信息,代码如下: ```javascript if (navigator.geolocation) { navigator.geolocation.getCurrentPosition(position => { const { latitude, longitude } = position.coords // 在这里调用天气 API 接口,传递经纬度参数 }) } else { console.error("Geolocation is not supported by this browser.") } ``` 接下来,你需要调用一个天气 API 接口来获取天气信息。这里我们使用 OpenWeatherMap 提供的免费天气 API 接口。你可以在 OpenWeatherMap 注册一个账号,然后获取一个 API Key。 以下是一个可以获取天气信息的 Vue.js 组件,代码中使用了 axios 库来发送 HTTP 请求: ```vue <template> <div> <h1>{{ city }}</h1> <p>{{ description }}</p> <p>{{ temperature }}°C</p> </div> </template> <script> import axios from 'axios' export default { data() { return { city: '', description: '', temperature: '' } }, mounted() { if (navigator.geolocation) { navigator.geolocation.getCurrentPosition(position => { const { latitude, longitude } = position.coords const apiKey = 'your-api-key' // 替换成你自己的 OpenWeatherMap API Key const apiUrl = `https://api.openweathermap.org/data/2.5/weather?lat=${latitude}&lon=${longitude}&appid=${apiKey}&units=metric` axios.get(apiUrl) .then(response => { const { name, weather, main } = response.data this.city = name this.description = weather[0].description this.temperature = main.temp }) .catch(error => { console.error(error) }) }) } else { console.error("Geolocation is not supported by this browser.") } } } </script> ``` 在上面的代码中,我们使用了 Vue.js 的 data 属性来存储获取到的天气信息,并在模板中展示出来。在组件的 mounted 钩子函数中,我们调用了浏览器的 Geolocation API 获取用户的位置信息,并将经纬度参数传递给 OpenWeatherMap 的 API 接口,获取天气信息。在获取成功后,我们更新 data 属性中的值,以便在模板中展示出来。 你可以将上面的代码复制到一个 Vue.js 单文件组件中,然后在你的应用程序中使用这个组件,就可以根据用户的位置获取天气信息了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值