【使用高德开放平台API和js的Ajax代码实现定位并获得城市的天气情况和经纬度,检索关键词获得周边信息】

以下是使用高德开放平台API和JavaScript实现的Ajax请求来定位城市并获取天气情况的示例代码:




<!DOCTYPE html>
<html>
<head>
    <title>获取天气信息</title>
    <script src="https://webapi.amap.com/maps?v=1.4.15&key=您的高德API密钥"></script>
    <script src="https://a.amap.com/jsapi_demos/static/demo-center/js/demoutils.js"></script>
</head>
<body>
    <div id="container" style="width:600px;height:400px;"></div>
    <div id="tip"></div>
 
    <script>
        var map = new AMap.Map('container', {
            resizeEnable: true
        });
 
        // 使用HTML5定位
        map.plugin('AMap.Geolocation', function() {
            var geolocation = new AMap.Geolocation({
                enableHighAccuracy: true,  // 是否使用高精度定位,默认:true
                timeout: 10000            // 超过10秒后停止定位,默认:5s
            });
 
            geolocation.getCurrentPosition();
            AMap.event.addListener(geolocation, 'complete', onComplete);  //返回定位信息
            AMap.event.addListener(geolocation, 'error', onError);      //返回定位出错信息
        });
 
        // 解析定位结果
        function onComplete(data) {
            var str = ['定位成功'];
            str.push('经度:' + data.position.getLng());
            str.push('纬度:' + data.position.getLat());
            if(data.accuracy){
                str.push('精度:' + data.accuracy + ' 米');
            }
            // 获取天气信息
            getWeatherInfo(data.position.getLng(), data.position.getLat());
            document.getElementById('tip').innerHTML = str.join('<br>');
        }
 
        // 定位出错
        function onError(data) {
            document.getElementById('tip').innerHTML = '定位失败';
        }
 
        // 获取天气信息
        function getWeatherInfo(lng, lat) {
            var cityInfoUrl = "https://restapi.amap.com/v3/weather/weatherInfo?key=您的高德API密钥&city=" + encodeURIComponent(lng) + "," + encodeURIComponent(lat);
            var xhr = new XMLHttpRequest();
            xhr.open("GET", cityInfoUrl, true);
            xhr.onreadystatechange = function() {
                if (xhr.readyState == 4 && xhr.status == 200) {
                    var response = JSON.parse(xhr.responseText);
                    if(response && response.lives && response.lives.length > 0) {
                        var live = response.lives[0];
                        console.log(live);
                        // 这里可以处理live

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日