• vue高德地图JS API 实现海量点标记展示


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

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

    实现效果:

    dc8ee3fa810d49a0beaea6addf850ca3.png

    1c796890f1164038a1c8967fd6b99a7b.png

    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的脚本引入之前进行设置,否则设置无效。

    实现代码

    1. <template>
    2. <div>
    3. <div id="container">div>
    4. div>
    5. template>

    安装@amap/amap-jsapi-loader

    1. npm install @amap/amap-jsapi-loader --save
    2. //或者
    3. yarn add @amap/amap-jsapi-loader --save

    引入

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

     方法

    1. mounted() {
    2. this.loadmap();
    3. }

    地图初始化配置 

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

    实现海量点方法:

    注意事项:

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

    1. handlePoint() {
    2. AMapUI.load(["ui/misc/PointSimplifier"], (PointSimplifier,$) =>{
    3. if (!PointSimplifier.supportCanvas) {
    4. alert("当前环境不支持 Canvas!");
    5. return;
    6. }
    7. var pointSimplifierIns = new PointSimplifier({
    8. map: this.map, //所属的地图实例
    9. getPosition: (item) =>{
    10. if (!item) {
    11. return null;
    12. }
    13. var parts = item.split(",");
    14. //返回经纬度
    15. return [parseFloat(parts[0]), parseFloat(parts[1])];
    16. // return item;
    17. },
    18. getHoverTitle: (dataItem, idx) =>{
    19. return idx + ": " + dataItem;
    20. },
    21. renderOptions: {
    22. //点的样式
    23. pointStyle: {
    24. content:"custom_path",
    25. width: 6,
    26. height: 6,
    27. fillStyle: "rgba(153, 0, 153, 1)",
    28. },
    29. //鼠标hover时的title信息
    30. hoverTitleStyle: {
    31. position: "top"
    32. }
    33. }
    34. });
    35. window.pointSimplifierIns = pointSimplifierIns;
    36. this.$http.post("后端接口",{
    37. //传递的参数配置
    38. }).then((res)=>{
    39. // 测试数据
    40. // const mapData =[
    41. // '114.29816166666667,30.57257',
    42. // '114.28119666666667,30.552911666666667',
    43. // '114.3028,30.59048333333333',
    44. // '114.29160666666667,30.556718333333333',
    45. // '114.2914,30.56986',
    46. // '114.28456,30.553633333333334',
    47. // '114.28102666666666,30.558086666666668',
    48. // '114.30773333333333,30.59782',
    49. // '114.29436,30.56962',
    50. // '114.28113333333333,30.558556666666668',
    51. // '114.29082666666666,30.559493333333332',
    52. // '114.28120333333334,30.558518333333332',
    53. // '114.28676,30.567103333333332',
    54. // '114.28902666666667,30.56107',
    55. // '114.28892,30.55321',
    56. // '114.28824666666667,30.552106666666667',
    57. // '114.28989333333334,30.571036666666668',
    58. // '114.28078666666667,30.567476666666668',
    59. // '114.29738333333333,30.58175333333333',
    60. // '114.30185333333333,30.58015333333333',
    61. // '114.28097333333334,30.558096666666668',
    62. // '114.29002666666666,30.571',
    63. // '114.29001333333333,30.55475',
    64. // '114.30334666666667,30.59148',
    65. // '114.28780833333333,30.551283333333334',
    66. // '114.30313333333334,30.59095333333333',
    67. // '114.29437166666666,30.586803333333332',
    68. // '114.28254333333334,30.548951666666667'
    69. // ]
    70. // 接口获取到的数进行处理
    71. // 数据格式 const mapData =['经度1,纬度1','经度2,纬度2']
    72. let mapData= [];
    73. res.data.data.forEach(item=>{
    74. mapData.push(item.longitude+","+item.latitude)
    75. });
    76. console.log(mapData,"push数据");
    77. pointSimplifierIns.setData(mapData);
    78. }).catch();
    79. // pointMouseover pointMouseout
    80. pointSimplifierIns.on("pointClick",(e, record)=> {
    81. // console.log(e.type, record);
    82. console.log(record.data);
    83. });
    84. });
    85. }


    ⭐️⭐️⭐️  作者:船长在船上
    🚩🚩🚩  主页:来访地址船长在船上的博客
    🔨🔨🔨  简介:CSDN前端领域优质创作者,资深前端开发工程师,专注前端开发,在CSDN总结工作中遇到的问题或者问题解决方法以及对新技术的分享,欢迎咨询交流,共同学习

    👉👉👉  欢迎来访船长在船上的博客,如有疑问可以留言、评论,看到后会及时回复。      

  • 相关阅读:
    哈希表与有序表
    Python 连接数据库添加字段
    prometheus基本介绍 prometheus和zabbix的区别 grafana可视化工具
    协议-序列化-http-Cookie-Session-https
    1375. 二进制字符串前缀一致的次数-前序遍历法
    Leetcode1833. 雪糕的最大数量
    SpringBoot启动失败报错,spring.profiles.active:@env@中环境变量@无法识别报错_active: @env@
    Linux高级笔记
    redis高级案列case
    行为学派 进化计算
  • 原文地址:https://blog.csdn.net/SmartJunTao/article/details/126426615