官方文档:海量点标记-覆盖物-教程-地图 JS API | 高德地图API

需求:根据后台接口返回的部分数据,这里仅做展示 ,可参考使用。 可以加入弹窗点击的时候。

实现效果:

JSAPI 的加载

JS API 2.0 版本提供了两种方案引入地图 JSAPI:

1. 使用官网提供的 JSAPI Loader 进行加载;

2. 以常规 JavaScript 脚本的方式加载;

注意:为避免地图数据协议和前端资源不匹配导致页面运行报错,只允许在线加载 JSAPI,禁止进行本地转存、与其它代码混合打包等用法。

使用 JSAPI Loader (推荐)

JSAPI Loader是我们提供的 API 加载器,可帮助开发者快速定位、有效避免加载引用地图 JSAPI 各种错误用法,具有以下特性:

  • 支持以 普通JS 和 npm包 两种方式使用;
  • 有效避免错误异步加载导致的 JSAPI 资源加载不完整问题;
  • 对于加载混用多个版本 JSAPI 的错误用法给予报错处理;
  • 对于不合法加载引用 JSAPI 给予报错处理;
  • 支持指定 JSAPI 版本;
  • 支持插件加载;
  • 允许多次执行加载操作,网络资源不会重复请求,便于大型工程模块管理;
  • 支持IE9以上的浏览器,不支持IE8以下

注意(您在2021年12月02日申请以后的key需要配合您的安全密钥一起使用)

JSAPI key和安全密钥的使用

JSAPI key搭配代理服务器并携带安全密钥转发(安全)

1) 引入 JSAPI 使用 Loader 之前增加代理服务器设置脚本标签,设置代理服务器域名或地址,将下面示例代码中的「您的代理服务器域名或地址」替换为您的代理服务器域名或ip地址,其中_AMapService为代理请求固定前缀,不可省略或修改。

(注意您这 个设置必须是在加载loader.js的脚本引入之前进行设置,否则设置无效。)

实现代码

<template>
  <div>
    <div id="container"></div>
  </div>
</template>

安装@amap/amap-jsapi-loader

npm install @amap/amap-jsapi-loader --save
//或者
yarn add @amap/amap-jsapi-loader --save

引入

import AMapLoader from "@amap/amap-jsapi-loader";

 方法

mounted() {
    this.loadmap();
}

地图初始化配置 

loadmap() {
      return new Promise((reslove, reject) => {
        AMapLoader.load({
          key: "", // 申请好的Web端开发者Key,首次调用 load 时必填
          // version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
          plugins: ["AMap.ToolBar", "AMap.Scale", "AMap.Geocoder"], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
          AMapUI: {
            // 是否加载 AMapUI,缺省不加载
            version: "1.1", // AMapUI 缺省 1.1
            plugins: [] // 需要加载的 AMapUI ui插件
          }
        })
          .then(AMap => {
            this.map = new AMap.Map("container", {
              resizeEnable: true,
              zoom: 4,
              center: [116.397428, 39.90923] //中心点坐标
            });
 
            //地图控件
            this.map.addControl(new AMap.Scale());
            this.map.addControl(new AMap.ToolBar());
            this.map.setZoom(14); //设置缩放大小
 
            this.handlePoint();
 
            reslove();
          })
          .catch(e => {
            console.log(e, "高德地图加载失败");
            reject(e);
          });
      });
    },

实现海量点方法:

注意事项:

// 数据处理格式 const mapData =['经度1,纬度1','经度2,纬度2']

handlePoint() {
      AMapUI.load(["ui/misc/PointSimplifier"], (PointSimplifier,$) =>{
        if (!PointSimplifier.supportCanvas) {
          alert("当前环境不支持 Canvas!");
          return;
        }
 
        var pointSimplifierIns = new PointSimplifier({
          map: this.map, //所属的地图实例
 
          getPosition: (item) =>{
            if (!item) {
              return null;
            }
 
            var parts = item.split(",");
            //返回经纬度
            return [parseFloat(parts[0]), parseFloat(parts[1])];
            // return item;
          },
          getHoverTitle: (dataItem, idx) =>{
            return idx   ": "   dataItem;
          },
          renderOptions: {
            //点的样式
            pointStyle: {
              content:"custom_path",
              width: 6,
              height: 6,
              fillStyle: "rgba(153, 0, 153, 1)",
            },
            //鼠标hover时的title信息
            hoverTitleStyle: {
              position: "top"
            }
          }
        });
 
        window.pointSimplifierIns = pointSimplifierIns;
 
        this.$http.post("后端接口",{
          //传递的参数配置
        }).then((res)=>{
          // 测试数据
          // const mapData =[
            // '114.29816166666667,30.57257', 
            // '114.28119666666667,30.552911666666667', 
            // '114.3028,30.59048333333333', 
            // '114.29160666666667,30.556718333333333', 
            // '114.2914,30.56986', 
            // '114.28456,30.553633333333334', 
            // '114.28102666666666,30.558086666666668', 
            // '114.30773333333333,30.59782', 
            // '114.29436,30.56962', 
            // '114.28113333333333,30.558556666666668', 
            // '114.29082666666666,30.559493333333332', 
            // '114.28120333333334,30.558518333333332', 
            // '114.28676,30.567103333333332', 
            // '114.28902666666667,30.56107', 
            // '114.28892,30.55321', 
            // '114.28824666666667,30.552106666666667', 
            // '114.28989333333334,30.571036666666668', 
            // '114.28078666666667,30.567476666666668', 
            // '114.29738333333333,30.58175333333333', 
            // '114.30185333333333,30.58015333333333', 
            // '114.28097333333334,30.558096666666668', 
            // '114.29002666666666,30.571', 
            // '114.29001333333333,30.55475', 
            // '114.30334666666667,30.59148', 
            // '114.28780833333333,30.551283333333334', 
            // '114.30313333333334,30.59095333333333', 
            // '114.29437166666666,30.586803333333332', 
            // '114.28254333333334,30.548951666666667'
            // ]
 
          // 接口获取到的数进行处理
          // 数据格式 const mapData =['经度1,纬度1','经度2,纬度2']
          let mapData= [];
          res.data.data.forEach(item=>{
            mapData.push(item.longitude "," item.latitude)
          });
          console.log(mapData,"push数据");
          
        
          pointSimplifierIns.setData(mapData);
        }).catch();
        //  pointMouseover pointMouseout
        pointSimplifierIns.on("pointClick",(e, record)=> {
            // console.log(e.type, record);
            console.log(record.data);
        });
      });
}

到此这篇关于vue高德地图JS API实现海量点标记示例的文章就介绍到这了,更多相关vue 高德地图海量点标记内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

vue高德地图JS API实现海量点标记示例的更多相关文章

  1. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  2. vue自定义加载指令v-loading占位图指令v-showimg

    这篇文章主要为大家介绍了vue自定义加载指令和v-loading占位图指令v-showimg的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  3. vue使用动画实现滚动表格效果

    这篇文章主要为大家详细介绍了vue使用动画实现滚动表格效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. 关于Vue 监控数组的问题

    这篇文章主要介绍了Vue 监控数组的示例,主要包括Vue 是如何追踪数据发生变化,Vue 如何更新数组以及为什么有些数组的数据变更不能被 Vue 监测到,对vue监控数组知识是面试比较常见的问题,感兴趣的朋友一起看看吧

  5. Vue子组件props从父组件接收数据并存入data

    这篇文章主要介绍了Vue子组件props从父组件接收数据并存入data的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  6. Vue h函数的使用详解

    本文主要介绍了Vue h函数的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  7. VUE响应式原理的实现详解

    这篇文章主要为大家详细介绍了VUE响应式原理的实现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

  8. vue+Element ui实现照片墙效果

    这篇文章主要为大家详细介绍了vue+Element ui实现照片墙效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. vue+elemet实现表格手动合并行列

    这篇文章主要为大家详细介绍了vue+elemet实现表格手动合并行列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. iview+vue实现导入EXCEL预览功能

    这篇文章主要为大家详细介绍了iview+vue实现导入EXCEL预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部