mapbox导入本地geojson数据并渲染

贴个群号

WebGIS学习交流群461555818,欢迎大家。

成果图

在这里插入图片描述

思路与源码

我这里使用的是ant的upload组件

    <a-upload
        v-model:file-list="fileList"
        :showUploadList=false
        name="file"
        action="https://www.mocky.io/v2/5cc8019d300000980a055e76"
        :headers="headers"
        @change="handleChange"
    >
		打开文件
    </a-upload>

handleChange方法是这样写的,但是ant这个方法有个问题,不知为何会触发三次,还有待研究

      //获取文件
      handleFileUpload(file) {
        return new Promise((resolve, reject) => {
          const reader = new FileReader();
          reader.readAsText(file);
          reader.onload = (e) => {
            try {
              let result = JSON.parse(e.target.result);
              resolve(result); // 使用resolve返回结果
            } catch (error) {
              console.error("File cannot be read or JSON is invalid.");
              reject(error); // 使用reject返回错误信息
            }
          };
        })
      },
      //监听改变
      handleChange(info){
        this.handleFileUpload(info.file.originFileObj).then(res =>{
        //res即为结果
          console.log(info.file,res)
        })
      }

能读取到geojson文件,剩下的就简单了,就是怎么组织数据、存储数据,判断数据是点线面,配置上默认的样式。

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MapboxGL是一个用于在Web上创建交互式地图的强大库,它可以方便地渲染GeoJSON数据。当您尝试使用`addLayer()`方法添加GeoJSON到地图中时遇到`TypeError: Cannot read properties of undefined (reading 'addLayer')`这样的错误,通常表示在操作某个不存在的对象或变量时出现了问题。 这个错误可能是由于以下几个原因: 1. **初始化问题**:确保在调用`addLayer`之前,Mapbox GL已经被正确地初始化了。例如,可能忘了设置access token或者没有创建map实例。 ```javascript mapboxgl.accessToken = 'YOUR_ACCESS_TOKEN'; const map = new mapboxgl.Map({ container: 'map', // 容器ID style: 'mapbox://styles/mapbox/streets-v11', // 或者自定义样式 }); ``` 2. **GeoJSON数据无效**:提供的GeoJSON数据可能是空的、格式错误,或者还没有加载完成。检查GeoJSON是否已成功解析和包含地理信息。 3. **对象引用错误**:确认`addLayer`方法所属的对象是否已经正确获取。例如,如果你从多个源动态加载GeoJSON,确保正确处理每个数据集的回调函数。 4. **版本兼容性问题**:确认使用的Mapbox GL JS版本和你的代码兼容。某些API可能在旧版和新版中有改变。 为了解决这个问题,您可以按照以下步骤排查: 1. 检查初始化代码。 2. 在添加`addLayer`前打印地图实例,确认其存在。 3. 打印或调试GeoJSON数据,确保内容正确。 4. 使用`try-catch`块捕获并处理可能的错误。 如果问题仍然存在,请提供具体的代码片段以便于更准确地定位问题。相关问题如下:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值