接入高德地图

概述

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

效果示例

准备

成为开发者并创建 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);
                        });

                    });
相关推荐
灵感__idea23 分钟前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
yinuo1 小时前
轻松接入大语言模型API -04
前端
袋鼠云数栈UED团队2 小时前
基于 Lexical 实现变量输入编辑器
前端·javascript·架构
cipher2 小时前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
UrbanJazzerati2 小时前
非常友好的Vue 3 生命周期详解
前端·面试
AAA阿giao2 小时前
从零构建一个现代登录页:深入解析 Tailwind CSS + Vite + Lucide React 的完整技术栈
前端·css·react.js
亦妤2 小时前
JS执行机制、作用域及作用域链
javascript
兆子龙3 小时前
像 React Hook 一样「自动触发」:用 Git Hook 拦住忘删的测试代码与其它翻车现场
前端·架构
兆子龙4 小时前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构
SuperEugene4 小时前
表单最佳实践:从 v-model 到自定义表单组件(含校验)
前端·javascript·vue.js