反应传单和反应传单绘制

React leaflet and react-leaflet-draw

我正在尝试在传单地图上实现绘制功能。我创建了一个仅安装了 react-leaflet 的新应用程序,使用 npx create-react-app 并安装了以下软件包:

至此,我启动了应用程序,一切正常:地图显示正确,中间有一个标记。

然后我添加了react-leaflet-draw包,用npm install react-leaflet-draw,并在页面中导入它我得到以下错误:

./node_modules/react-leaflet-draw/dist/esm/EditControl.js
Attempted import error: 'MapControl' is not exported from 'react-leaflet'

这是完整代码:

import './App.css';
import 'leaflet/dist/leaflet.css';
import { MapContainer, TileLayer, Marker, Popup, MapControl } from 'react-leaflet'
import L from 'leaflet';
import icon from 'leaflet/dist/images/marker-icon.png';
import iconShadow from 'leaflet/dist/images/marker-shadow.png';
import iconRetina from 'leaflet/dist/images/marker-icon-2x.png';

import 'leaflet-draw/dist/leaflet.draw.css';
import { EditControl } from "react-leaflet-draw";


delete L.Icon.Default.prototype._getIconUrl;
L.Icon.Default.mergeOptions({
  iconRetinaUrl: iconRetina,
  iconUrl: icon,
  shadowUrl: iconShadow
})



function App() {
  return (
    <MapContainer center={[51.505, -0.09]} zoom={10} scrollWheelZoom={true}>
      <TileLayer
        attribution='&copy; <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
        url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
      />
      <Marker position={[51.505, -0.09]}>
        <Popup>
          A pretty CSS3 popup. <br /> Easily customizable.
    </Popup>
      </Marker>
    </MapContainer>
  );
}

export default App;

这个包有什么问题?它对 React 有效吗?

MapControl 添加到您的导入:

import { MapContainer, TileLayer, Marker, Popup, MapControl } from 'react-leaflet'

如果你检查这个 github issue 你会得出结论 react-leaflet-draw 只与 react-leaflet 版本兼容 2.x 而不是版本 3.x.

因此它在您的情况下不起作用,因为您使用的是 react-leaflet 版本 3.x.

如果您降级到 2.x 版本,它应该可以正常工作

最后但同样重要的是,您不需要导入 MapControl,因为包中不需要它。你只需要导入

import { EditControl } from "react-leaflet-draw"

就像你已经做的那样。 MapControl 在库内部使用,可能在较新版本中发生了一些变化,这就是您收到错误的原因。