在 Leaflet 上加载 KML 图层的最佳方法是什么?

dis*_*ast 2 kml leaflet

我必须在 Leaflet 应用程序上加载 KML 图层。经过一番浏览后,我发现一个名为 leaflet-kml 的库可以执行此操作。我可以通过两种方式加载 KML 图层:通过 KML 图层的 URI 或 KML 字符串。KML 存储在服务器中,我有后端代码可以检索 URI 和字符串表示形式。

这是使用 URI 的方法。

function LoadKML(containerName, name)
{
     let kmlURL = GetKmlURI(containerName, name);  
     let kmlLayer = new L.KML(kmlURL);
     map.addLayer(kmlLayer);
}

Run Code Online (Sandbox Code Playgroud)

这是使用 kml 字符串的方法。

function LoadKML(containerName, name)
{
     let kmlString = GetKmlString(containerName, name);  
     let kmlLayer = new L.KML.parseKML(kmlString);
     map.addLayer(kmlLayer);
}

Run Code Online (Sandbox Code Playgroud)

由于 CORS 限制,我无法使用第一种方法获取 URL。第二种方法返回一个字符串,但无法正确解析。

KML.js:77 Uncaught TypeError: this.parseStyles is not a function
    at new parseKML (KML.js:77)
    at LoadKML (Account:470)
    at Account:461
Run Code Online (Sandbox Code Playgroud)

我应该如何调用leaflet-kml中的函数?有没有可以轻松将 KML 加载到传单中的库?

geo*_*der 5

您可以使用 leaflet-omnivore。它是加载 KML 文件的最佳插件(https://github.com/mapbox/leaflet-omnivore

var kmlData = omnivore.kml('data/kmlData.kml', null, customLayer);
Run Code Online (Sandbox Code Playgroud)