下面是我的代码。我正在使用传单以苗条的方式绘制图形。但我收到错误“地图未定义”。我该如何解决这个问题?
<script>
import L from 'leaflet';
let map;
map = L.map("mapDemo", {
minZoom: 4,
maxZoom: 6
});
map.zoomControl.setPosition("bottomright");
var bounds = [
[-10, -10],
[10, 10]
];
map.fitBounds(bounds);
var markers = {
id1: { title: "Marker 1", coords: [1, 0], description: "Text for marker 1" },
id2: { title: "Marker 2", coords: [4, 2], description: "Text for marker 2" },
id3: { title: "Marker 3", coords: [8, 8], description: "Text for marker 3" }
};
var layers = L.layerGroup().addTo(map);
var titlesList = [];
var idToLayer = {};
var titleToId = {};
var idToTitle = {};
var idToText = {};
var markerOnClick = function () {
var mId = this.options.markerId;
};
$:each(markers, function (key, val) {
var markerOptions = {
markerId: key,
markerTitle: val["title"],
markerText: val["description"]
};
var marker = L.marker(val["coords"], markerOptions).addTo(map);
var popupContent = val["title"];
// Bind popup to marker click
marker.bindPopup(popupContent);
});
</script>
<div id="mapDemo">
</div>
另外,我想添加一个图像作为背景,坐标绘制在给定的图像上。
答案 0 :(得分:1)
您应该将 Leaflet 初始化代码包装在 onMount 中。 script 标签在元素被渲染到 DOM 之前运行,所以 mapDemo 元素还不存在。
我也不确定你想用 $:each
做什么——我认为你正在寻找 Object.entries(markers).forEach(([key, val]) => {})
。
这是带有 onMount 和每个重写的脚本标记。
<script>
import { onMount } from 'svelte';
import L from 'leaflet';
let map;
onMount(() => {
map = L.map("mapDemo", {
minZoom: 4,
maxZoom: 6
});
map.zoomControl.setPosition("bottomright");
var bounds = [
[-10, -10],
[10, 10]
];
map.fitBounds(bounds);
var markers = {
id1: {
title: "Marker 1",
coords: [1, 0],
description: "Text for marker 1"
},
id2: {
title: "Marker 2",
coords: [4, 2],
description: "Text for marker 2"
},
id3: {
title: "Marker 3",
coords: [8, 8],
description: "Text for marker 3"
}
};
var layers = L.layerGroup().addTo(map);
var titlesList = [];
var idToLayer = {};
var titleToId = {};
var idToTitle = {};
var idToText = {};
var markerOnClick = function() {
var mId = this.options.markerId;
};
Object.entries(markers).forEach(([key, val]) => {
var markerOptions = {
markerId: key,
markerTitle: val["title"],
markerText: val["description"]
};
var marker = L.marker(val["coords"], markerOptions).addTo(map);
var popupContent = val["title"];
// Bind popup to marker click
marker.bindPopup(popupContent);
});
})
</script>