微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

TypeError:无法读取React mapbox-gl项目中未定义的属性'getCanvasContainer'

如何解决TypeError:无法读取React mapbox-gl项目中未定义的属性'getCanvasContainer'

我正在使用mapBoxgl构建一个React MapBox项目(注意:不是React包装器版本)。到目前为止,我已经能够将想要添加内容添加到地图和数据库中,但是我无法将所有数据显示标记/点/弹出窗口。

我在Chrome中收到的消息是TypeError:无法读取未定义的属性'getCanvasContainer'。

我想知道这是我的地图本身(缺少MapBox的React包装器)还是坐标问题。现在,我正在手动将坐标设置为const coords,但如果不这样做,则会收到消息:错误LngLatLike参数必须指定为LngLat实例,对象{lng:, lat:},对象{lon:,lat:}或[,]数组,但我也无法解决。这是我要检查的一些代码

export default class Map extends Component {
    constructor(props) {
        super(props);
        this.state = {
        allBuildings: [],lng: 5,lat: 45,zoom: 3,}

        componentDidMount() {
            const map = new mapBoxgl.Map({
            container: this.mapContainer,style: 'mapBox://styles/mapBox/streets-v11',center: [this.state.lng,this.state.lat],zoom: this.state.zoom
            });

            map.on('move',() => {
                this.setState({
                lng: map.getCenter().lng.toFixed(4),lat: map.getCenter().lat.toFixed(4),zoom: map.getZoom().toFixed(4)
                });
                });

            let marker = new mapBoxgl.Marker({
                draggable: true,color: "blue"
            }).setLngLat([16.40,50.54]).addTo(map) 


            marker.on('dragend',() => {
                const lngLat = marker.getLngLat();
                this.setState({
                    lng: lngLat.lng,lat: lngLat.lat
                })
            })
            
            this.getMarkers()
            
            }

            getMarkers = () => {
                axios
                .get('/api/add')
                .then(res => {
                        this.setState({
                            allBuildings: res.data
                  res.data.forEach(building => {
                   const popup = new mapBoxgl.Popup({ offset: 10})
                   const coords = [building.lng,building.lat]
                  new mapBoxgl.Marker({
                       color: 'orange',draggable: false })
                  .setPopup(popup)
                  .setLngLat(building.lng,building.lat)
                  .setHTML(<div>add later</div>)
                  .addTo(this.map)
                  })  
                })
                .catch(err => {
                    console.log(err)
                })
            }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?