![](/img/trans.png)
[英]Want to Update the Center of MapContainer of React-Leaflet-js
[英]The Center in a MapContainer in React-Leaflet-js Won't Update
我最近开始使用 React.js,并且正在使用 React-Leaflet-js 进行项目。 我的问题是,每当以下代码中的position
变量更新时,我的MapContainer
都不会更改页面的center
:
...
render() {
const position = [this.state.location.lat, this.state.location.lng];
return (
<MapContainer
className="map"
center={position}
zoom={this.state.zoom}
scrollWheelZoom={true}>
...
作为参考,正在更新的state
变量如下所示:
state = {
location: {
lat: 40.7128,
lng: -74.0060,
},
haveUsersLocation: false,
zoom: 13,
}
奇怪的是, position
设置为{position}
的marker
会在position
变量发生变化而不是MapContainer
的center
时自动更新。 我不确定为什么map
没有响应并调整其center
。
注意:我尝试查看此内容,但没有回答我的问题。 请帮忙。
center
属性只是初始化地图,如果你想更新实际显示的地图的中心,如果你想要平滑的动画,你必须使用setView
或flyTo
。 为了获得 Leaflet Map 参考,您需要使用钩子useMap
。
function FlyMapTo() {
const map = useMap()
useEffect(() => {
map.flyTo(position)
}, [position])
return null
}
return (
<MapContainer
className="map"
center={position}
zoom={this.state.zoom}
scrollWheelZoom={true}>
<FlyMapTo />
</MapContainer>
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.