带有多个标记的 React Leaflet LayersControl.Overlay
React Leaflet LayersControl.Overlay with multiple markers
我有一张地图显示城市中每个不同 public 设施的标记,我想要一组复选框来根据其类型过滤这些设施,一个用于类型的复选框。每个类型都会有多个标记,地图只会显示选中的标记。
我正在使用 react-leaflet v3.
这是我尝试做的:
<MapContainer center={[50,50]} zoom={13} scrollWheelZoom={true} whenCreated={setMap}>
<TileLayer
attribution='© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
/>
<LayersControl position='topright'>
{typologies.map((typology, index) => (
<LayersControl.Overlay key={index} checked name={typology}>
{publicFacilities.filter((publicFacility) => publicFacility.typology == typology ).map((publicFacility) => (
<Marker key={publicFacility._id} position={publicFacility.coordinates} />
))}
</LayersControl.Overlay>
))}
</LayersControl>
</MapContainer>
typologies 是一个字符串列表,publicFacilities 是一个对象列表。
但是通过这种方法,我得到了每个设施的复选框。
您可以使用 lodash groupBy 按类型构建您的群组。
然后使用 Layer Groups 让几个 Marker 表现得像一个 Overlay。
行中的内容:
const groupedByTypology = groupBy(publicFacilities, "typology");
return <LayersControl>
{Object.keys(groupedByTypology).map(typology => (
<LayersControl.Overlay key={typology} name={typology}>
<LayerGroup>
{groupedByTypology[typology].map(publicFacility => (
<Marker key={publicFacility._id} position={publicFacility.coordinates} />
))}
</LayerGroup>
</LayersControl.Overlay>
))}
</LayersControl>
我有一张地图显示城市中每个不同 public 设施的标记,我想要一组复选框来根据其类型过滤这些设施,一个用于类型的复选框。每个类型都会有多个标记,地图只会显示选中的标记。
我正在使用 react-leaflet v3.
这是我尝试做的:
<MapContainer center={[50,50]} zoom={13} scrollWheelZoom={true} whenCreated={setMap}>
<TileLayer
attribution='© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
/>
<LayersControl position='topright'>
{typologies.map((typology, index) => (
<LayersControl.Overlay key={index} checked name={typology}>
{publicFacilities.filter((publicFacility) => publicFacility.typology == typology ).map((publicFacility) => (
<Marker key={publicFacility._id} position={publicFacility.coordinates} />
))}
</LayersControl.Overlay>
))}
</LayersControl>
</MapContainer>
typologies 是一个字符串列表,publicFacilities 是一个对象列表。
但是通过这种方法,我得到了每个设施的复选框。
您可以使用 lodash groupBy 按类型构建您的群组。
然后使用 Layer Groups 让几个 Marker 表现得像一个 Overlay。
行中的内容:
const groupedByTypology = groupBy(publicFacilities, "typology");
return <LayersControl>
{Object.keys(groupedByTypology).map(typology => (
<LayersControl.Overlay key={typology} name={typology}>
<LayerGroup>
{groupedByTypology[typology].map(publicFacility => (
<Marker key={publicFacility._id} position={publicFacility.coordinates} />
))}
</LayerGroup>
</LayersControl.Overlay>
))}
</LayersControl>