Reactjs Web应用程序谷歌地图在PC本地主机上工作但在移动设备上不工作

标签 reactjs google-maps react-redux react-router react-google-maps

我在 React 上制作的 Web 应用程序在 PC 上表现出色,但我最近注意到,当我从手机上的 localhost:3000 打开同一个应用程序时,它无法打开。正如我提到的,它是一个 react 应用程序,所以它的一些组件加载,例如在给定的图片中,您可以看到我的导航栏、侧边栏和页脚按照它们应该打开的方式打开,但中间是 google map 应该在,它应该在 PC 上,但在移动设备上却不存在,人们的任何帮助都会有所帮助,因为我们对这件事一无所知。

我们什么也没尝试,因为我们只是不知道这个问题源自何处。

import React,{Component} from 'react';
import { GoogleMap,Marker,InfoWindow } from '@react-google-maps/api';
import {connect} from 'react-redux';
import {mapTypeChangeSync} from '../actions/map';
import donut from "./icons/donut.png";


class GoogleMapWrapper extends Component{


    handleType = () => this.props.mapTypeChangeSync(this.map.getMapTypeId());
    /*
    onLoad = (map) => {
        const elt = document.createElement('p');
        elt.innerHTML = 'maps loadedddd...';
        document.body.appendChild(elt);
        this.map = map;
    }
    */

    render(){
        const {currentLocation,mappedMarkers,onClick,map} = this.props;
        //console.log(donut);
        //console.log('ff',new google.maps.LatLng(24.919988335566842,67.1343894711640));
        if (currentLocation.lat && currentLocation.lng)
            return (
                <GoogleMap mapContainerStyle= {{height: "100vh",
                 width: "100vw" }} center = {currentLocation} zoom = {20}
                 onClick = {onClick? (e) => onClick(e):undefined} 
                 mapTypeId = {map} onMapTypeIdChanged = {this.handleType}
                 onLoad = {map => this.map = map}>

                    <Marker position = {currentLocation} 
                     icon = {{url:donut}} />

                    <InfoWindow position = {currentLocation}>
                        <p>Location Found</p>
                    </InfoWindow>

                    {mappedMarkers.map((marker,i) => (
                        <Marker key = {marker.id?marker.id:i}
                         position = {marker.location}
                         label = {marker.id?marker.id:undefined} />
                    ))}

                </GoogleMap>
                );

        else
            return null;

    }
}

const mapStateToProps = ({currentLocation,objects,map},{cachedMarker}) => {

    const mappedMarkers = objects.map(obj =>({
        id:obj.id,
        location:obj.location
    }));

    console.log('cached Marker:',cachedMarker)

    if (cachedMarker)
        mappedMarkers.push(cachedMarker);

    return {currentLocation,mappedMarkers,map};
}



export default connect(mapStateToProps,
            {mapTypeChangeSync})(GoogleMapWrapper);

this is our normal output app screen this is what we get when we open it on our mobile

最佳答案

根据这个github issue ,将版本设置为 3.30 可以解决问题,如下所示:

<GoogleMapReact
  bootstrapURLKeys={{
    key: process.env.REACT_APP_MAP_KEY,
    v: '3.30',
  }}
/>

就我个人而言,这对我不起作用,但也许对你有用。

关于Reactjs Web应用程序谷歌地图在PC本地主机上工作但在移动设备上不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57017686/

相关文章:

android - 来自 Android Java 代码的 ionic 电容器处理事件

javascript - 我应该在 Redux 的什么地方编写复杂的异步流?

arrays - 更新 redux 数组中的多个项目

javascript - React Component div id 不会隐藏 map 循环中使用的内容

xcode - 升级了 React Native,现在找不到 glog/logging.h 文件

javascript - 当我使用 createAsyncThunk 时,action.payload 返回未定义

javascript - 在 Reactjs 中比较许多 prevProps 和 nextProps 的最佳方法是什么?

java - Android Studio : Can I Refer to a Started Service in Java Code?

iOS Google Maps SDK 与 MapKit 滚动

ios - Google map GMSPanoramaView api 被阻止