Реагировать + гугл-карты-реагировать сделать несколько создателей
Почему мой код не работает? Показывает только один маркер, который я использую Google-карты-реагировать
const data = {"shops":[{"name":"Tienda1","location":{"lat":-34.4712726922992,"lng":-58.75985026359558}},
{"name":"Tienda2","location":{"lat":-34.4684599474558,"lng":-58.757007122039795}},
{"name":"Tienda3","location":{"lat":-34.46932677829895,"lng":-58.760215044021606}},
{"name":"Tienda4","location":{"lat":-34.470989653082555,"lng":-58.76484990119934}}]}
return (
<div>
<Map google={window.google} initialCenter={{lat: -34.47509000000001, lng: -58.75374599999998}} zoom={10}>
{
data.shops.map((x)=>(<Marker key={uuid.v4()} {...x}/>))
}
</Map>
</div>
)
1 ответ
Я потратил некоторое время на интеграцию карты Google с конфигурацией машинописного текста. так что я делюсь своим кодом с вами, посмотрю, он поможет вам и другим.
import React, {
Component
} from 'react'
import {
Map,
GoogleApiWrapper,
Marker,
InfoWindow
} from 'google-maps-react';
declare
var google: any;
interface IPageProps {
google ? : any;
center: ILatAndLng;
markersOptions: any[];
zoom: number;
containerStyle: any;
flightPositions ? : ILatAndLng[]
address ? : string;
centername ? : string
}
interface ILatAndLng {
lat: number;
lng: number;
}
export class MapComponent extends Component < IPageProps, any > {
constructor(props: any) {
super(props);
this.state = {
activeMarker: {},
selectedPlace: {},
showingInfoWindow: false
};
}
private onMarkerClick = (props: any, marker: any) =>
this.setState({
activeMarker: marker,
selectedPlace: props,
showingInfoWindow: true
});
private onInfoWindowClose = () =>
this.setState({
activeMarker: null,
showingInfoWindow: false
});
private onMapClicked = () => {
if (this.state.showingInfoWindow) {
this.setState({
activeMarker: null,
showingInfoWindow: false
});
}
};
public render() {
const {
markersOptions,
center,
zoom,
containerStyle,
flightPositions,
address
} = this.props
return ( <
Map google = {
this.props.google
}
onClick = {
this.onMapClicked
}
initialCenter = {
center
}
center = {
{
lat: center.lat,
lng: center.lng
}
}
/** @ts-ignore */
flightPlanCoordinates = {
flightPositions
}
zoom = {
zoom
}
containerStyle = {
containerStyle
} >
{
(Array.isArray(markersOptions) && markersOptions.length > 0) ? markersOptions.map((marker: any, markerIndex: number) => {
return ( <
Marker key = {
'marker ' + markerIndex
}
/** @ts-ignore */
label = {
markerIndex.toString()
}
name = {
markerIndex.toString()
}
onClick = {
this.onMarkerClick
}
position = {
{
lat: +marker.latitude,
lng: +marker.longitude
}
}
/>
)
}) : (center.lat !== null) && < Marker
/** @ts-ignore */
name = {
address
}
label = {
'H'
}
onClick = {
this.onMarkerClick
}
position = {
{
lat: center.lat,
lng: center.lng
}
}
/>} <
InfoWindow
marker = {
this.state.activeMarker
}
/** @ts-ignore */
onClose = {
this.onInfoWindowClose
}
visible = {
this.state.showingInfoWindow
} >
<
div >
<
h4 > {
/** @ts-ignore */
this.state.selectedPlace.name
} < /h4> <
/div> <
/InfoWindow> <
/Map>
);
}
}
const Container = GoogleApiWrapper({
apiKey: process.env.REACT_APP_GOOGLE_MAP_KEY,
version: "3.38",
region: 'US'
})(MapComponent as any) as any;
export default Container;
Экспорт класса по умолчанию MapRender extends Component {
renderMarker(marker, index) {
return (<Marker
key={index}
zIndex={index}
position={new window.google.maps.LatLng(
marker.lat,
marker.lng
)}
/>)
}
render() {
//multiMarkers will contain all Markers like a array simple
var multiMarkers = []
const data = {
"shops": [{ "name": "Tienda1", "location": { "lat": -34.4712726922992, "lng": -58.75985026359558 } },
{ "name": "Tienda2", "location": { "lat": -34.4684599474558, "lng": -58.757007122039795 } },
{ "name": "Tienda3", "location": { "lat": -34.46932677829895, "lng": -58.760215044021606 } },
{ "name": "Tienda4", "location": { "lat": -34.470989653082555, "lng": -58.76484990119934 } }]
}
// After push all Markers in multiMarkers need only insert it in the map
data.shops.map((marker, index) => {
multiMarkers.push(this.renderMarker(marker, index))
return null
})
return (
<div>
<Map google={window.google}
initialCenter={{
lat: -34.47509000000001,
lng: -58.75374599999998
}}
zoom={10}>
{multiMarkers}
</Map>
</div>
)
}
}
Убедитесь, что вы используете API правильно, как указано в примере здесь. Вы должны были бы создать карту с withGoogleMap
а также GoogleMap
,
Кроме того, каждый маркер использует ключ position
вместо location
чтобы указать точку на карте.
[{
position: {
lat: 25.0112183,
lng: 121.52067570000001,
},
key: `Taiwan`,
defaultAnimation: 2,
}, ...]
После внесения этих изменений ваш код должен работать.