javascript - 类型错误 super 表达式

标签 javascript reactjs react-leaflet

我正在使用reactjs开发传单 map ,但是当我实现<MarkerClusterGroup>时出现此错误来自react-leaflet-markercluster .

TypeError: Super expression must either be null or a function, not object

错误如下:

enter image description here

这是 JavaScript:

import React, { Component } from 'react';
import L from 'leaflet';
import { Map, TileLayer, Marker, Popup } from 'react-leaflet';
import MarkerClusterGroup from 'react-leaflet-markercluster';
import 'react-leaflet-markercluster/dist/styles.min.css';


// code for map marker icon
var myIcon = L.icon({
    iconUrl: '',
    iconSize: [25, 41],
    iconAnchor: [12.5, 41],
    popupAnchor: [0, -41]
});

export default class BikeMap extends Component {
    constructor(props) {
    super(props);
        this.state = {
            location: {
              lat: 51.505,
              lng: -0.09,
        },
        bikeData: [],
        isLoading: true,
        haveUsersLocation: false,
        zoom: 3
    }
}

//code for loading
componentWillMount() {
    setTimeout(() => this.setState({
        isLoading: false
    }), 2000);
}

componentDidMount() {
    //code to get the bike information
    fetch('https://api.citybik.es/v2/networks')
        .then(res => {
            if (!res.ok) {
                throw new Error(res.status);
            }
            return res.json();
        })
        .then(response => {
            const networkData = response.networks;
            this.setState({
                bikeData: networkData
            });
        })
        .catch(error => {
            console.log(error);
        });

    //code to get the user's location(if so desires)
    navigator.geolocation.getCurrentPosition((position) => {
        this.setState({
            location: {
                lat: position.coords.latitude,
                lng: position.coords.longitude
            },
            haveUsersLocation: true,
            zoom: 6
        });
    }, () => {
        console.log('Uops! The user didnt give its location!');
        fetch('https://ipapi.co/json')
            .then(res => {
                if (!res.ok) {
                    throw new Error(res.status);
                }
                return res.json();
            })
            .then(location => {
                this.setState({
                    location: {
                        lat: location.latitude,
                        lng: location.longitude
                    },
                    haveUsersLocation: true,
                    zoom: 13
                });
            })
            .catch(error => {
                console.log(error);
            })
    });
}


render() {
    const { isLoading } = this.state;
    const position = [this.state.location.lat, this.state.location.lng]
    const bikeData = this.state.bikeData;

    if (isLoading) {
        return <div className="spinner"></div>
    }

    return (
        <Map className="map markercluster-map" center={position} zoom={this.state.zoom}>
            <TileLayer
                attribution="&amp;copy <a href=&quot;http://osm.org/copyright&quot;>OpenStreetMap</a> contributors"
                url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
            />
            <MarkerClusterGroup>
                {
                    bikeData && bikeData.map((data, index) => {
                        const company = data.company;
                        if (company) {
                            const companyList = company.map((station, index) => {
                                return (
                                    <div key={index}>{station}</div>
                                )
                            })
                            return (
                                <Marker
                                    icon={myIcon}
                                    key={data.id}
                                    position={[data.location.latitude, data.location.longitude]}>
                                    <Popup>
                                        <b>City:</b> {data.location.city} <br />
                                        <b>Country:</b> {data.location.country} <br />
                                        <b>Name of Network:</b> {data.name} <br />
                                        <b>Number of Stations:</b> {data.company.length} <br />
                                        <b>Name of Stations:</b> {companyList}
                                    </Popup>
                                </Marker>
                            )
                        }
                        return <div key={index}>No Data</div>
                    })
                }
            </MarkerClusterGroup>
        </Map>
    )
}
}

我正在使用:

"leaflet": "^1.3.4",
"leaflet.markercluster": "^1.4.1",
"prop-types": "^15.6.2",
"react": "^16.5.2",
"react-dom": "^16.5.2",
"react-leaflet": "^2.0.1",
"react-leaflet-markercluster": "^1.1.8"

谢谢!

最佳答案

请使用<a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="c8baada9abbce5a4ada9aea4adbce5a5a9baa3adbaaba4bdbbbcadba88fae6f8e6f8e5baabf9" rel="noreferrer noopener nofollow">[email protected]</a>

https://codesandbox.io/embed/31j028qp25

关于javascript - 类型错误 super 表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52587241/

相关文章:

javascript - 找不到 React-Leaflet 标记文件

javascript - 如何在 jquery 或 javascript 中使用 window.location.replace

javascript - 将图像添加到动态 className jQuery

reactjs - Redux-form - 表单上的 onChange 未触发

reactjs - ag-Grid:框架组件缺少方法 getValue()

javascript - 使 react-leaflet 可以离线使用

r - Shiny +传单 react 功能不起作用

javascript - 如何在 jQuery 中使用一个元素的属性值来定位另一个具有相同属性值的元素?

javascript - SharePoint 在单击时传递文本框的值以更新列表列

reactjs - 我们能否组合不同的 Redux 应用程序来创建一个更大的应用程序?