React Leaflet:动态设置多边形的样式

时间:2018-01-01 12:32:44

标签: reactjs leaflet react-leaflet

如何以编程方式更改多边形的颜色?

我用于GeoJSONs here的解决方案不起作用。虽然当我检查元素时,我可以看到

style:{color: "red"}

尽管如此,地图显示的是蓝色多边形。

以下是我的组件的相关部分:

render() {
    const {
        id,
        name,
        geoJSON,
        zoomLevel,
        selectedPlot,
        plotBeingEdited
    } = this.props;
    const markerPosition = position(geoJSON);

    let style = () => {
        return {
            color: 'blue'
        };
    };
    if (selectedPlot === id) {
        style = () => {
            return {
                color: 'red'
            };
        };
    }

    if (zoomLevel > 14 && plotBeingEdited === id) {
        return <PlotPolygon id={id} geoJSON={geoJSON} />;
    } else if (zoomLevel > 14) {
        return (
            <Polygon
                ref="plot"
                style={style()}
                id={id}
                positions={[positions(this.props)]}
                onClick={() => {
                    this.props.selectPlot(id);
                }}
            />
        );
    }

1 个答案:

答案 0 :(得分:1)

将颜色道具作为对象传递:

<Polygon
   ...
   color={selectedPlot === id ? 'red' : 'blue'}
/>