首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法将geoJson层添加到打开层映射中

无法将geoJson层添加到打开层映射中
EN

Stack Overflow用户
提问于 2022-05-14 22:05:03
回答 1查看 209关注 0票数 0

使用Open和传单-侧边栏-v2,我将侧边栏添加到我的地图中,这是可行的。然而,我也需要在我的地图上添加另一层,这一层将勾勒出每个国家。我把坐标存储在'borders.json‘文件中。我试图使用D3.json导入边界坐标,然后使用L.geoJson将新层添加到地图中。

我目前收到以下错误消息:

Uncaught TypeError: t.getLayerStatesArray is not a function

这是我代码的相关部分。

代码语言:javascript
复制
var map = new ol.Map({
  target: "map",
  layers: [
    new ol.layer.Tile({
      source: new ol.source.OSM(),
    }),
  ],
  view: new ol.View({
    center: ol.proj.transform([7, 51.2], "EPSG:4326", "EPSG:3857"),
    zoom: 3,
  }),
});

var sidebar = new ol.control.Sidebar({
  element: "sidebar",
  position: "left",
});
map.addControl(sidebar);

d3.json(("borders.json"), function (json){
    function style(feature) {
        return {
            fillColor: "transparent",
            weight: 1,
            opacity: 0.4,
            color: 'grey',
            fillOpacity: 0.3
        }
    }

    geojson = L.geoJson(json, {
      style: style,
    }).addTo(map);
})

我想我可能不正确地将geojson层添加到我的地图中,但我不知道哪里出了问题。我花了很多时间玩它,但没有运气。

任何帮助都是非常感谢的。

干杯,击打

EN

Stack Overflow用户

回答已采纳

发布于 2022-05-26 06:23:30

如果不知道代码中其他可能的相关部分,就很难判断问题是什么。首先,我将检查borders.json的内容是否遵循有效GeoJSON格式

这可能与您的问题无关,但您是否有理由将style声明为类似于function style(feature) { ... }的函数?

看起来像是 -- L.geoJsonstyle属性接受对象而不是函数。

票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72244162

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档