![](/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.