vue中高德地图使用 Marker 标点 - 标点数据快到 1000 时页面卡顿问题解决(已解决 - 多方面原因)+ 海量点功能实现解决

目录

  • 1.业务需求
  • 2.最初实现及出现的问题
  • 3.解决 - `1000` 个标点时页面就出现 `卡顿` 问题
  • 4.使用海量点、聚合标点后还有卡顿,排查其他原因
  • 5.最终解决
    • 5.1页面中list数据渲染问题解决
    • 5.2地图相关实例不要放在 vue 的可响应数据中
  • 页面展示

1.业务需求

需要在 高德地图 中标点,标点数量可能 上万个

2.最初实现及出现的问题

  • 【最初实现】使用高德地图的 Marker 标点
    • Marker 实现标点代码
      // 遍历list数据一个一个标点
      let warnning = new AMap.Marker({zIndex: type === 'alarm' ? 14 : 12,icon: icon,position: [item.longitude, item.latitude],anchor: 'bottom-center',extData: {tabType: type,...item}
      })
      this.markerList.push(warnning) // 用于
      warnning.on('click', this.markerClick)
      // warnning.emit('click', { target: warnning });//
      map.add(warnning)
      
  • 【问题】1000 个标点时页面就出现 卡顿

3.解决 - 1000 个标点时页面就出现 卡顿 问题

想尽各种办法:

  1. 【海量点第一种方法】:海量点 MassMarks 官方示例 (代码示例如下)
  2. 【海量点第二种方法】:标注和标注图层-海量点 官方示例
  3. 【点聚合】:MarkerCluster 官方示例

【海量点第一种方法】代码

<script>
/* 注释掉的代码与当前功能无关 */
let map = null
// let infoWindowCon = null
// let contextMenu = null
let makerPeak = nullexport default {name: 'mapManager',data() {return {// ...dangerSucMass: null // 【关键代码】海量点图层}},methods: {// 使用【海量点第一种方法】实现标点completeAddMarker(data) {this.dangerSucMass?.clear()const list = (data || []).map((item, index) => {return {id: item.id,name: item.address,lnglat: [item.longitude, item.latitude],style: 0,extData: {tabType: 'dangerSuceess',...item}}})this.dangerSucMass = new AMap.MassMarks(list, {opacity: 0.8,zIndex: 111,cursor: 'pointer',style: [{url: require('@/assets/image/green.png'),anchor: AMap.Pixel(0, 0),size: new AMap.Size(10, 10),zIndex: 3}]})this.dangerSucMass.setMap(map)this.dangerSucMass.on('click', this.successMarkerClick)},// 展示/隐藏图标isShowSucMass(e) {if (e) {this.dangerSucMass.show()this.markerTip.open(map)} else {this.dangerSucMass.hide()this.markerTip.close()}},//监听successMarkerClick(e) {console.log('e--successMarkerClick--打印', e)// 添加点击marker时的提示if (this.markerTip) {this.markerTip.close() // 关闭提示}const data = e.data.extDataconsole.log('e.data.extData----打印', data)this.infoWindowData = { ...data, type: 'dangerSuceess' }const position = [data.longitude, data.latitude]map.setCenter(new AMap.LngLat(position[0], position[1]), true)this.markerTip = new AMap.InfoWindow({ // 提示插件position: new AMap.LngLat(position[0], position[1]), // 经纬度content: this.$refs['infoW'].$el,offset: new AMap.Pixel(5, 0) // 偏移位置})this.markerTip.open(map)// this.$refs.infoW.open({...e.data.extData, typeTab: 'dangerSuceess'})},}
}
</script>

4.使用海量点、聚合标点后还有卡顿,排查其他原因

以上三种办法 - 页面还是卡顿 - 基于以上三种解决办法排查到以下多方面原因:

  1. 页面中有list数据 列表渲染,数据过多,页面数据渲染过多也会导致页面卡顿
  2. 地图相关的变量data 中声明(此处以【海量点第一种方法】为例)
    • 以上 【海量点第一种方法】代码 中可以看到,海量点实例 dangerSucMassdata 中声明 ↓↓↓
    • 所有 地图相关的实例不要放在 vue 的可响应数据中,响应数据会 劫持属性地图的属性会被修改,另外,劫持的属性可能和渲染有关,那么 会增加很多响应的计算,会很卡; 参考别人遇到的类似的问题-官方解释
      在这里插入图片描述

5.最终解决

5.1页面中list数据渲染问题解决

最初地图标点和list数据使用的是一套数据
【解决】

  • 地图标点数据页面渲染数据 分成两套列表数据
    • 地图标点数据:获取所有标点数据
    • 页面渲染数据列表:改成分页获取数据,单次获取一部分数据

5.2地图相关实例不要放在 vue 的可响应数据中

最终解决办法【海量点第一种方法】代码

<script>
/* 注释掉的代码与当前功能无关 */
let map = null
// let infoWindowCon = null
// let contextMenu = null
let makerPeak = null
let dangerSucMass = null // 【关键代码】【解决代码】海量点实例 - 不在 data 中export default {name: 'mapManager',data() {return {// ...// dangerSucMass: null // 【关键代码】海量点实例}},methods: {// 使用【海量点第一种方法】实现标点completeAddMarker(data) {dangerSucMass?.clear()const list = (data || []).map((item, index) => {return {id: item.id,name: item.address,lnglat: [item.longitude, item.latitude],style: 0,extData: {tabType: 'dangerSuceess',...item}}})dangerSucMass = new AMap.MassMarks(list, {opacity: 0.8,zIndex: 111,cursor: 'pointer',style: [{url: require('@/assets/image/green.png'),anchor: AMap.Pixel(0, 0),size: new AMap.Size(10, 10),zIndex: 3}]})dangerSucMass.setMap(map)dangerSucMass.on('click', this.successMarkerClick)},// 展示/隐藏图标isShowSucMass(e) {if (e) {dangerSucMass.show()this.markerTip.open(map)} else {dangerSucMass.hide()this.markerTip.close()}},//监听successMarkerClick(e) {console.log('e--successMarkerClick--打印', e)// 添加点击marker时的提示if (this.markerTip) {this.markerTip.close() // 关闭提示}const data = e.data.extDataconsole.log('e.data.extData----打印', data)this.infoWindowData = { ...data, type: 'dangerSuceess' }const position = [data.longitude, data.latitude]map.setCenter(new AMap.LngLat(position[0], position[1]), true)this.markerTip = new AMap.InfoWindow({ // 提示插件position: new AMap.LngLat(position[0], position[1]), // 经纬度content: this.$refs['infoW'].$el,offset: new AMap.Pixel(5, 0) // 偏移位置})this.markerTip.open(map)// this.$refs.infoW.open({...e.data.extData, typeTab: 'dangerSuceess'})},}
}
</script>

页面展示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/433025.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LLM - 理解 多模态大语言模型(MLLM) 的 幻觉(Hallucination) 与相关技术 (七)

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/142463789 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 多模态…

使用session来实现验证码发送功能

一、什么是session&#xff1f; Session由服务器创建&#xff0c;并为每一次会话分配一个Session对象。同一个浏览器发起的多次请求&#xff0c;同属于一次会话&#xff08;Session&#xff09;。首次使用到Session时&#xff0c;服务器会自动创建Session&#xff0c;并创建Co…

【HarmonyOS】鸿蒙多Toast显示工具类

【HarmonyOS】封装可以同时显示多个toast的工具类 src/main/ets/common/MyPromptActionUtil.ets import { ComponentContent, PromptAction, window } from kit.ArkUI; import { BusinessError } from kit.BasicServicesKit;// MyPromptInfo 类用于生成唯一的 dialogID export …

SQL 性能调优

什么是 SQL 性能调优 SQL 性能调优是优化 SQL 查询以尽可能高效地运行的过程&#xff0c;从而减少数据库负载并提高整体系统性能。这是通过各种技术实现的&#xff0c;例如分析查询执行计划、优化索引和重写查询以确保最佳执行路径。目标是最大限度地减少执行查询所需的时间和…

OceanBase技术解析: 执行器中的自适应技术

在《OceanBase 数据库源码解析》这本书中&#xff0c;对于执行器的探讨还不够深入&#xff0c;它更多地聚焦于执行器的并行处理机制。因此&#xff0c;通过本文与大家分享OceanBase执行器中几种典型的自适应技术&#xff0c;作为对书中执行器部分的一个补充。 提升数据库分析性…

【开源免费】基于SpringBoot+Vue.JS技术交流分享平台(JAVA毕业设计)

博主说明&#xff1a;本文项目编号 T 053 &#xff0c;文末自助获取源码 \color{red}{T053&#xff0c;文末自助获取源码} T053&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…

OpenHarmony(鸿蒙南向)——平台驱动指南【MIPI DSI】

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ 持续更新中…… 概述 功能简介 DSI&#xff08;Display Serial Interface&#x…

Apache Iceberg 概述

Apache Iceberg概述 一、what is Apache Iceberg&#xff1f; 为了解决数据存储和计算引擎之间的适配的问题&#xff0c;Netflix开发了Iceberg&#xff0c;2018年11月16日进入Apache孵化器&#xff0c;2020 年5月19日从孵化器毕业&#xff0c;成为Apache的顶级项目。 Apache…

java通过webhook给飞书发送群消息

现在使用飞书的人越来越多了&#xff0c;飞书有一个最大的好处&#xff0c;可以使用webhook简便的发送群消息。而在工作中&#xff0c;也经常会因为一些运维方面的工作&#xff0c;需要给飞书发送群消息&#xff0c;来实时提醒相关负责人,及时处理工作。 一、先看一下效果吧&a…

OpenCV图像文件读写(5)从文件系统中读取图像的标准函数imread()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 从文件加载图像。 imread 函数从指定的文件加载图像并返回它。如果图像无法读取&#xff08;因为文件缺失、权限不当、格式不受支持或无效&…

精简解析:二叉树的遍历方法及其应用场景

目录标题 二叉树的遍历方法及其应用场景摘要 1. 前序遍历 (Preorder Traversal)1.1 定义1.2 代码实现1.3 应用场景 2. 中序遍历 (Inorder Traversal)2.1 定义2.2 代码实现2.3 应用场景 3. 后序遍历 (Postorder Traversal)3.1 定义3.2 代码实现3.3 应用场景 4. 层次遍历 (Level …

Linux 文件 IO 管理(第三讲:文件系统)

Linux 文件 IO 管理&#xff08;第三讲&#xff1a;文件系统&#xff09; 进程为什么默认要打开文件描述符为 0&#xff0c;1 和 2 的文件呢&#xff1f;文件系统物理磁盘简单认识存储结构对磁盘存储进行逻辑抽象分组 —— 文件系统Block Bitmapinode Tableinode BitmapGDT(Gro…

C语言实现归并排序(Merge Sort)

目录 一、递归实现归并排序 1. 归并排序的基本步骤 2.动图演示 3.基本思路 4.代码 二、非递归实现 1.部分代码 2.代码分析 修正后代码&#xff1a; 归并过程打印 性能分析 复杂度分析 归并排序是一种高效的排序算法&#xff0c;采用分治法&#xff08;Divide and Con…

【芋道源码】gitee很火的开源项目pig——后台管理快速开发框架使用笔记(微服务版之本地开发环境篇)

后台管理快速开发框架使用笔记&#xff08;微服务版之本地开发环境篇&#xff09; 后台管理快速开发框架使用笔记&#xff08;微服务版之本地开发环境篇&#xff09; 后台管理快速开发框架使用笔记&#xff08;微服务版之本地开发环境篇&#xff09;前言一、如何获取项目&#…

计算机毕业设计宠物领养网站我的发布领养领养用户信息/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序

目录 1.课题背景 2.课题意义 ‌ 3.技术介绍 4.技术性需求 4.1后端服务‌&#xff1a; 4.2 前端展示‌ 5.数据库设计‌&#xff1a; 6.系统性能‌&#xff1a; 7.安全性‌&#xff1a; 8. 功能介绍&#xff1a; 9. 部分代码 1.课题背景 近年来&#xff0c;随着宠物饲养数量…

2024年9月25日--- Spring-IOC 1

一 Spring的概要 1.1 简介 Spring&#xff0c;春天的意思&#xff0c;意指给软件行业带来春天。2002年&#xff0c;Rod Jahnson首次推出了Spring框架雏形interface21框架。2004年3月24日&#xff0c;Spring框架以interface21框架为基础&#xff0c;经过重新设计&#xff0c;发…

《深度学习》—— ResNet 残差神经网络

文章目录 一、什么是ResNet&#xff1f;二、残差结构&#xff08;Residual Structure&#xff09;三、Batch Normalization&#xff08;BN----批归一化&#xff09; 一、什么是ResNet&#xff1f; ResNet 网络是在 2015年 由微软实验室中的何凯明等几位大神提出&#xff0c;斩获…

linux信号 | 学习信号三步走 | 全解析信号的产生方式

前言&#xff1a;本节内容是信号&#xff0c; 主要讲解的是信号的产生。信号的产生是我们学习信号的第二个阶段。 我们已经学习过第一个阶段——信号的概念与预备知识&#xff08;没有学过的友友可以查看我的前一篇文章&#xff09;。 以及我们还没有学习信号的第三个阶段——信…

89个H5小游戏源码

下载地址&#xff1a;https://download.csdn.net/download/w2sft/89791650 亲测可用&#xff0c;代码完整&#xff0c;都是htmljs&#xff0c;保存到本地即可。 游戏截图&#xff1a;

Universal Link配置不再困扰,Xinstall来帮忙

在移动互联网时代&#xff0c;App的推广和运营至关重要。而Universal Link作为一种能够实现网页与App间无缝跳转的技术&#xff0c;对于提升用户体验、引流至App具有显著效果。今天&#xff0c;我们就来科普一下Universal Link的配置方法&#xff0c;并介绍如何通过Xinstall这款…