0

所以我正在使用传单反应,我需要添加一些圆圈标记。

现在这段代码可以工作......有时。在地图上单击应该添加一个圆形标记,但有时它不是。看似随机,它不会添加可见标记。如果我更改缩放级别,有时标记会变得可见,但并非总是如此。所有代码每次都运行,所以并不是 addMarker() 没有被调用,最后一个标记的删除(通过清除标记层)总是运行。

谢谢,埃德。

4

1 回答 1

2

看来您没有使用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='&copy; <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/

于 2017-07-20T05:39:19.223 回答