gpt4 book ai didi

javascript - 谷歌地图 React/Redux 组件

转载 作者:搜寻专家 更新时间:2023-11-01 05:29:16 24 4
gpt4 key购买 nike

我的 React/Redux 组件用于处理 Google map :

import React, { Component, PropTypes } from 'react'
import { connect } from 'react-redux'

import { changeMapCenter } from '../actions'

class Map extends Component {

componentDidMount() {
let script = document.createElement('script')

script.setAttribute('type', 'text/javascript')
script.setAttribute('src', 'https://maps.googleapis.com/maps/api/js?key=AIzaSyCXg-YGJF&callback=initMap')
document.getElementsByTagName('head')[0].appendChild(script)

window.initMap = () => {
this.map = new google.maps.Map(document.getElementById('map'), {
center: this.props.defaultCenter,
zoom: this.props.defaultZoom
});

this.map.addListener('center_changed', (event) => {
let center = {
lat: this.map.getCenter().lat(),
lng: this.map.getCenter().lng()
}
this.props.onMapCenterChanging(center)
});
}
}

render() {
return (
<div id='map'></div>
);
}
}

const mapStateToProps = (state) => {
return {
mapPoints: state.mapPoints
}
}

const mapDispatchToProps = (dispatch) => {
return {
onMapCenterChanging: (center) => {
dispatch(changeMapCenter(center))
}
}
}

export default connect(mapStateToProps, mapDispatchToProps)(Map)

正如您现在看到的,这个组件只是初始化 map 并监听 map 中心的变化。现在我需要渲染一些标记(mapPoints)。从 Google API 文档我可以做到(例如):

  var marker = new google.maps.Marker({
position: myLatlng,
map: map,
title: 'Click to zoom'
});

但是我该如何使用“React 风格”呢?因为绘图标记不是“渲染”HTML,它只是调用 JS Google Maps API 函数。我可以将此逻辑放在“initMap”函数中,但我的“mapPoints”可以更改。我应该将 JS 逻辑(删除已删除的点/绘制新点)放在“渲染”函数中吗?谢谢!

最佳答案

通常,一个包含一些命令式 API(比如 jQuery 小部件或类似的)的 React 组件通过不渲染任何东西(或者只渲染最少的内容,比如容器 div)来实现,然后更新包装的小部件在 React 生命周期方法中。实际上已经有一些组件包装了 Google Maps API,特别是 https://www.fullstackreact.com/articles/how-to-write-a-google-maps-react-component/引导您完成操作。

关于javascript - 谷歌地图 React/Redux 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37768422/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com