首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TypeError:超级表达式必须为null或函数,而不是对象。

TypeError:超级表达式必须为null或函数,而不是对象。
EN

Stack Overflow用户
提问于 2018-12-14 11:20:18
回答 2查看 1.3K关注 0票数 1

正如您在这个主题中看到的,我的问题是,当我想导入react传单旋转标记,只导入时,我的就会抛出这条消息。

我用的是反应传单v2.1.2。

下面是我的js代码片段:

代码语言:javascript
复制
import React, { Component } from 'react';
import { Map, TileLayer, Marker, Popup } from 'react-leaflet';
import L, { map, addTo } from 'leaflet';
import RotatedMarker from 'react-leaflet-rotatedmarker'
import './App.css'

//importing marker/icon
var ego_veh_icon = L.icon({
    iconUrl: require('./design/icons/ego_veh_arrow.svg'),
    iconSize: [150, 200],
    iconAnchor: [82.5, 40],
    popupAnchor: [0, -25],
});

var av_veh_icon = L.icon({
    iconUrl: require('./design/icons/autonom_veh_arrow.svg'),
    iconSize: [150, 200],
    iconAnchor: [82.5,55],
    popupAnchor: [-5, -25],
});

var nav_veh_icon = L.icon({
    iconUrl: require('./design/icons/non_autonom_veh_arrow.svg'),
    iconSize: [150, 200],
    iconAnchor: [82.5, 60],
    popupAnchor: [-10, -25],
});

class Map_hmi extends Component {
    constructor() {
        super();
        this.state = {
            markers: [[x, y]],
            param: null,
        };
    }

    // ego veh position 
    ego_veh = {
        lat: x,
        lng: y,
    }

     // nav veh position 
     nav_veh = {
        lat: x,
        lng: y,
    }

     // av veh1 position 
     av_veh1 = {
        lat: x,
        lng: y,
    }

    // av veh2 position 
    av_veh2 = {
        lat: x
        lng: y,
    }

    render() {
        
        const ego_veh_pos = [this.ego_veh.lat, this.ego_veh.lng]
        const nav_veh_pos = [this.nav_veh.lat, this.nav_veh.lng]
        const av_veh1_pos = [this.av_veh1.lat, this.av_veh1.lng]
        const av_veh2_pos = [this.av_veh2.lat, this.av_veh2.lng]
        return (
            // declaring the map
            <Map
                className="map"
                center={ego_veh_pos}
                zoom={15}
                zoomControl={false}
            >
                <TileLayer
                    attribution='&amp;copy <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
                    url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
                />  
                    {/* <RotatedMarker position={position} rotationAngle={180} rotationOrigin={'center'} /> */}
                    {/* ego veh */}
                    <Marker 
                        position={ego_veh_pos}
                        icon= {ego_veh_icon}>
                        <Popup>
                        EGO <br/>
                        </Popup>
                    </Marker>
                    {/* nav veh */}
                    <Marker 
                        position={nav_veh_pos}
                        icon= {nav_veh_icon}>
                        <Popup>
                        NAV <br/>
                        </Popup>
                    </Marker>
                    {/* av veh1 */}
                    <Marker 
                        position={av_veh1_pos}
                        icon= {av_veh_icon}>
                        <Popup>
                        AV <br/>
                        </Popup>
                    </Marker>
                     {/* av veh2 */}
                     <Marker 
                        position={av_veh2_pos}
                        icon= {av_veh_icon}>
                        <Popup>
                        AV <br/>
                        </Popup>
                    </Marker>
                )}
            </Map>
            
        );
    }
}

export default Map_hmi;

因此,我的代码在没有导入的情况下运行良好,但只要导入它:

TypeError:超级表达式必须为null或函数,而不是对象

我只想旋转图标..。

有什么帮助吗?

问候

EN

回答 2

Stack Overflow用户

发布于 2018-12-17 22:00:09

提供了另一个答案似乎是正确的,套餐react-leaflet v2包不兼容。

对于react-leaflet v2库,可以像这样实现RotatedMarker组件(提供与react-leaflet-rotatedmarker包相同的行为):

代码语言:javascript
复制
import React, { Component } from "react";
import { withLeaflet } from "react-leaflet";
import { Marker } from "react-leaflet";
import { Marker as LeafletMarker } from 'leaflet-rotatedmarker';

const RotatedMarker = props => {
  const setupMarker = marker => {
    if (marker) {
      if (props.rotationAngle)
        marker.leafletElement.setRotationAngle(props.rotationAngle);
      marker.leafletElement.setRotationOrigin(props.rotationOrigin);
    }
  };

  return <Marker ref={el => setupMarker(el)} {...props} />;
};

RotatedMarker.defaultProps = {
  rotationOrigin: "center"
};

export default withLeaflet(RotatedMarker);

演示页

票数 2
EN

Stack Overflow用户

发布于 2018-12-14 13:53:46

tldr:使用此注释中的代码可以解决您的问题。https://github.com/verdie-g/react-leaflet-rotatedmarker/issues/1#issuecomment-427285940

更长的答案:react-leaflet v2在组件扩展的方式上与v1有很大的不同。如果您查看react-leaflet-rotatedmarker的代码,您将看到以下一行:https://github.com/verdie-g/react-leaflet-rotatedmarker/blob/master/src/RotatedMarker.jsx#L5

Marker类的扩展在v2中不起作用,这就是引发该错误的原因。要获得更多关于为什么会这样的信息,您可以查看我在react-leaflet回购中提出的问题。https://github.com/PaulLeCam/react-leaflet/issues/506

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

https://stackoverflow.com/questions/53778772

复制
相关文章

相似问题

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