所以我正在使用传单反应,我需要添加一些圆圈标记。
现在这段代码可以工作......有时。在地图上单击应该添加一个圆形标记,但有时它不是。看似随机,它不会添加可见标记。如果我更改缩放级别,有时标记会变得可见,但并非总是如此。所有代码每次都运行,所以并不是 addMarker() 没有被调用,最后一个标记的删除(通过清除标记层)总是运行。
谢谢,埃德。
所以我正在使用传单反应,我需要添加一些圆圈标记。
现在这段代码可以工作......有时。在地图上单击应该添加一个圆形标记,但有时它不是。看似随机,它不会添加可见标记。如果我更改缩放级别,有时标记会变得可见,但并非总是如此。所有代码每次都运行,所以并不是 addMarker() 没有被调用,最后一个标记的删除(通过清除标记层)总是运行。
谢谢,埃德。
看来您没有使用react-leaflet包。我建议尝试一下。以下是一些示例代码,说明如何在点击事件中向地图添加标记:
const React = window.React;
const { Map, TileLayer, Marker, Popup } = window.ReactLeaflet;
class SimpleExample extends React.Component {
constructor() {
super();
this.state = {
markers: [[51.505, -0.09]]
};
}
addMarker = (e) => {
const {markers} = this.state
markers.push(e.latlng)
this.setState({markers})
}
render() {
return (
<Map
center={[51.505, -0.09]}
onClick={this.addMarker}
zoom={13}
>
<TileLayer
attribution='© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
url='http://{s}.tile.osm.org/{z}/{x}/{y}.png'
/>
{this.state.markers.map((position, idx) =>
<Marker key={`marker-${idx}`} position={position}>
<Popup>
<span>A pretty CSS3 popup. <br/> Easily customizable.</span>
</Popup>
</Marker>
)}
</Map>
);
}
}
window.ReactDOM.render(<SimpleExample />,
document.getElementById('container'));
这是一个显示实现的jsfiddle:https ://jsfiddle.net/q2v7t59h/413/