我正在使用'google-map-react'库,并且我已经尝试了所有方法,但是标记没有显示出来。我以多种方式将坐标传递给标记,但没有一个奏效。这是我的代码和存储库:
https://github.com/jorginyu/ubica
import React, { Component } from 'react';
import GoogleMapReact from 'google-map-react';
const API_KEY = 'WTFULOOKINAT';
const contacts = [
{ name: 'Spiderman', lat: 41.529616, lng: 2.434130 },
{ name: 'Iron Man', lat: 41.528103, lng: 2.433834 },
{ name: 'Hulk', lat: 41.530192, lng: 2.422994 }
];
const MarkersC = (text ) => <div className="contact">{text}</div>;
export default class MapComponent extends Component {
constructor(props) {
super(props);
this.state = {
center: {
lat: 41.528452,
lng: 2.434195
},
zoom: 18
}
}
render() {
return (
// Important! Always set the container height explicitly
<div className="mt-5" style={{ height: '80vh', width: '100%' }}>
<GoogleMapReact
bootstrapURLKeys={{ key: API_KEY }}
defaultCenter={this.state.center}
defaultZoom={this.state.zoom}
>
{contacts.map((contact,i) => {
<MarkersC position={{lat: contact.lat, lng: contact.lng}} text={contact.name} key={i} />
})}
</GoogleMapReact>
</div>
);
}
}
我该怎么办?谢谢您的时间:)
如果打开浏览器的控制台,将会看到错误。问题出在您的MarkerC
组件上,以及您如何try获取text
属性。
组件的参数是具有所有属性传递给它的对象。
您不需对其进行结构分解即可获得text
,您只需使用整个参数并尝试显示它即可。
所以您需要适当地将其分解为const MarkersC = ( {text} ) => ..
代替
const MarkersC = ( text ) => <div className="contact">{text}</div>;
应该是
const MarkersC = ( {text} ) => <div className="contact">{text}</div>;
更新
[刚刚注意到,google-map-react
期望在标记上找到lat
和lng
属性。您已将它们包装在position
属性中,因此找不到它们。
所以您的用法应该是
两个
<MarkersC lat={contact.lat} lng={contact.lng} text={contact.name} key={i} />
或散布具有这些属性的整个contact
对象
<MarkersC {...contact} key={i} />
因此lat
,lng
和text
都是MarkersC
组件的直接属性。
LMAO。这是哈哈哈哈的格式。我删除了空格:
THEN:]>
{ contacts.map((contact, i) => <MarkersC lat={contact.lat} lng={contact.lng} text={contact.name} key={i} /> ) }
现在:
{
contacts.map((contact, i) => <MarkersC lat={contact.lat} lng={contact.lng} text={contact.name} key={i} /> )
}