接入高德地图

概述

项目有时候需要用到地图相关的功能,常见的可以接入高德、百度、腾讯这些,总体来说,大体的接入方式差不多,以下通过高德地图接入项目做一期示例。

效果示例

准备

成为开发者并创建 key

注意:

key非常重要,接入地图的凭证

登录控制台

登录 高德开放平台控制台,如果没有开发者账号,请 注册开发者

创建 key

进入应用管理,创建新应用,新应用中添加 key,服务平台选择 Web端(JS API)。

获取 key 和密钥

创建成功后,可获取 key 和安全密钥。

提示

安全密钥机制旨在提升用户对 key 的安全有效管理,降低明文传输被窃取的风险。 2021年12月02日后创建的 key 必须配备安全密钥一起使用,具体用法参见 JS API 安全密钥使用

快速上手

安全配置

以下必须配置,否则部分功能无法使用!

js 复制代码
   <script type="text/javascript">
        window._AMapSecurityConfig = {
            securityJsCode: "97de88ef2cd411e6b92e56fa60e7ded3",//控制台创建的安全秘钥
        };
    </script>

基本地图

html 复制代码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width" />
    //地图加载器
    <script src="https://webapi.amap.com/loader.js"></script>
    <title>HELLO,AMAP!</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        #panel {
            position: absolute;
            background-color: white;
            max-height: 90%;
            overflow-y: auto;
            top: 10px;
            right: 10px;
            width: 280px;
        }

        html,
        body,
        #container {
            width: 100%;
            height: 100%;
        }
    </style>
</head>

<body>

    <div id="container"></div>
        <script>
        AMapLoader.load({
            key: "ecb74ca8a999af4d93d8211abaa96b92", //申请好的Web端开发者 Key,调用 load 时必填
            version: "2.0", //指定要加载的 JS API 的版本,缺省时默认为 1.4.15
        })
            .then((AMap) => {
            // 地图实例
                const map = new AMap.Map("container");
            })
            .catch((e) => {
                console.error(e); //加载错误提示
            });

    </script>
</body>

</html>

添加地图控件

缩放插件

js 复制代码
 // 注册缩放插件
  map.plugin(["AMap.ToolBar"], function () {
      const ToolBar = new AMap.ToolBar();
      map.addControl(ToolBar);
    });

比例尺控件

js 复制代码
 // 注册比例尺控件
  map.plugin(["AMap.Scale"], function () {
      const Scale = new AMap.Scale();
      map.addControl(Scale);
    });

定位控件

js 复制代码
 // 注册定位控件
  map.plugin(["AMap.Geolocation"], function () {
      const Geolocation = new AMap.Geolocation();
      map.addControl(Geolocation);
    });

图层切换控件

js 复制代码
 // 注册图层切换控件
  map.plugin(["AMap.MapType"], function () {
      const MapType = new AMap.MapType();
      map.addControl(MapType);
    });

搜索

可使用内置的搜索控件,也可以使用搜索结果自定义ui

js 复制代码
    map.plugin(["AMap.PlaceSearch"], function () {
                        const placeSearch = new AMap.PlaceSearch({
                            pageSize: 5, //单页显示结果条数
                            pageIndex: 1, //页码
                            city: "010", //兴趣点城市
                            citylimit: true, //是否强制限制在设置的城市内搜索
                            map: map, //展现结果的地图实例
                            panel: "panel", //参数值为你页面定义容器的 id 值<div id="my-panel"></div>,结果列表将在此容器中进行展示。
                            autoFitView: true, //是否自动调整地图视野使绘制的 Marker 点都处于视口的可见范围
                        });
                        placeSearch.search("北京大学", function (status, result) {
                        //这里可以根据结果自定义UI
                            console.log("搜索结果", status, result);
                        });

                    });
相关推荐
xiaotao1312 分钟前
Vite 完全学习指南
前端·vite·前端打包
军军君0116 分钟前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
IT枫斗者23 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
hotlinhao24 分钟前
Nginx rewrite last 与 redirect 的区别——Vue history 模式短链接踩坑记录
前端·vue.js·nginx
ZC跨境爬虫27 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
下北沢美食家30 分钟前
CSS面试题2
前端·css
weixin_4617694037 分钟前
npm create vue@latest 错误
前端·vue.js·npm
WindrunnerMax38 分钟前
从零实现富文本编辑器#13-React非编辑节点的内容渲染
前端·架构·github
四千岁38 分钟前
Ollama+OpenWebUI 最佳组合:本地大模型可视化交互方案
前端·javascript·后端
写不来代码的草莓熊40 分钟前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js