How to add markers bulk in leaflet?(如何在传单中批量添加标记?)
问题描述
我有一个包含约 30k 个元素的数组,我需要为每个元素创建带有标记的地图.我使用markerclusters并尝试优化添加时刻.
I have an array with ~30k elements and I need to create map with markers for each of them. I use markerclusters and trying to optimize adding moment.
for (var i = 0; i < myItems.length; i++) {
var item = myItems[i];
marker = new L.marker([item[2],item[3]], {
icon: mapOpts.myIcon
}).bindPopup(item[1]);
markers.addLayer(marker);
}
即使是谷歌浏览器也需要大约 40 秒来完成这个循环.我不想看到FF的结果.
Even Google Chrome takes about 40 sec to do this loop. I don't want to see FF's result.
有没有办法优化向地图添加许多元素?
Is there any way to optimize adding many elements to map?
推荐答案
var array = [];
for (var i = 0; i < myItems.length; i++) {
var item = myItems[i];
marker = new L.marker([item[2],item[3]], {
icon: mapOpts.myIcon
}).bindPopup(item[1]);
array.push(marker);
}
markers.addLayers(array);
有关详细信息,请参阅 文档.
See the docs for more details.
这篇关于如何在传单中批量添加标记?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何在传单中批量添加标记?
基础教程推荐
- 直接将值设置为滑块 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01