当我展开手风琴面板时,谷歌地图数据将不会出现

Google Map Data will not appear when i expand the accordion panel

本文关键字:数据 谷歌地图 手风琴      更新时间:2023-09-26

当我在我的网页上展开我的导航面板时,谷歌地图不显示任何东西,它只是显示为灰色。只有当我打开控制台地图才会出现。我需要改变我的代码地图出现与它的标记和位置,我已经编程它去。当你把地图放在面板外面时,它会完美地工作。如果有人可以扩展我写的代码来帮助,那就太好了。

HTML代码:

    <button class="accordion">Navigation</button>
        <div class="panel">
            <div id="map" style="width:60%;height:300px"></div>
            </div>
CSS Code:
button.accordion {
            background-color: #eee;
            color: #444;
            cursor: pointer;
            padding: 18px;
            width: 100%;
            border: none;
            text-align: left;
            outline: none;
            font-size: 15px;
            transition: 0.4s;
        }
        button.accordion.active, button.accordion:hover {
            background-color: #ddd;
        }
        div.panel {
            padding: 0 18px;
            display: none;
            background-color: white;
        }
        div.panel.show {
            display: block;
        }

脚本代码:

<script>
        var acc = document.getElementsByClassName("accordion");
        var i;
        for (i = 0; i < acc.length; i++) {
            acc[i].onclick = function(){
                this.classList.toggle("active");
                this.nextElementSibling.classList.toggle("show");
            }
        }
    </script>

    <script>
        function myMap() {
            var mapCanvas = document.getElementById("map");
            var myCenter = new google.maps.LatLng(51.508742,-0.120850);
            var mapOptions = {center: myCenter, zoom: 15};
            var map = new google.maps.Map(mapCanvas,mapOptions);
            var marker = new google.maps.Marker({
                position: myCenter,
                icon: "poi.png"
            });
            marker.setMap(map);
        }

        </script>
        <script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyB37us778WYnwNjHftUm3oL2oduV_WOt_E&callback=myMap"></script>

您的手风琴显示处理程序只需要触发地图大小调整:

google.maps.event.trigger(map, "resize");

第一个脚本块的代码变成:

<script>
    var acc = document.getElementsByClassName("accordion");
    var i;
    for (i = 0; i < acc.length; i++) {
        acc[i].onclick = function(){
            this.classList.toggle("active");
            this.nextElementSibling.classList.toggle("show");
            google.maps.event.trigger(map, "resize");  //added
        }
    }
</script>

工作小提琴:https://jsfiddle.net/vv0xtbrw/(见第14行);