API Карт Google дает мне net :: ERR_ABORTED 400 - PullRequest
0 голосов
/ 28 декабря 2018

Я пытаюсь найти вам API Google Maps (Maps Javascript API).Сначала я сделал простой HTML-файл и сделал простую карту, это сработало.Затем я сделал более сложный с метками и полилиниями, это сработало.

Сделав это, я решил переместить его в свое веб-приложение. Дело в том, что мое приложение работает с xhtml, а не с html.Тем не менее это должно работать.Но это не так.

Я прочитал много форумов, но не могу найти решение своей проблемы.Вот простой код карты, который я попробовал в html-файле:

<head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no">
    <meta charset="utf-8">
    <title>My Test</title>
    <style>
        #map {
        height: 100%;
        }

        html, body {
        height: 100%;
        margin: 0;
        padding: 0;
        }
    </style>
</head>
<body>
    <div id="map"></div>
    <script>
        function initialize() {
            map = new google.maps.Map(document.getElementById('map'), {
                center: {lat: -34.397, lng: 150.644},
                zoom: 8
            });
        }
    </script>
    <script async defer
    src="https://maps.googleapis.com/maps/api/js?key=MYAPI&callback=initialize">
    </script>
</body>

Вот та же информация, но в моем .xhtml-файле: (мой xhtml находится над шаблоном, поэтому в нем нетинформация о голове.)

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
            xmlns:h="http://java.sun.com/jsf/html"
            xmlns:f="http://java.sun.com/jsf/core"
            xmlns:ui="http://java.sun.com/jsf/facelets"
            xmlns:p="http://primefaces.org/ui">
<p:dialog  header="#{msg['MAP']}" footer="#{msg['TOURSYS.FOOTER.TITLE']} | #{msg['TOURSYS.FOOTER.VERSION']} | #{msg['TOURSYS.FOOTER.LAST.MODIFICATION.DATE']}" widgetVar="mapDialog" modal="true"  height="auto" width="auto">
    <h:form id="mapForm">
        <html>
            <style>
                #map {
                    height: 100%;
                }

                html, body {
                    height: 100%;
                    margin: 0;
                    padding: 0;
                }
            </style>
            <body>
                <div id="map"></div>

                <script>
                    function initialize() {
                        map = new google.maps.Map(document.getElementById('map'), {
                            center: {lat: -34.397, lng: 150.644},
                            zoom: 8
                        });
                    }

                </script>

                <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key=MYAPI&amp;callback=initialize;"/>

            </body>
        </html>      
    </h:form>           
</p:dialog>  

В моей консоли Google появляется следующая ошибка:

GET https://maps.googleapis.com/maps/api/js?key=MYAPI&callback=initialize; net :: ERR_ABORTED400

Мое приложение запущено в проекте maven с Primefaces 6.2.7

1 Ответ

0 голосов
/ 17 января 2019

Theres точка с запятой (;), включенная в src вашего вызова JS.

Ваш вызов:

<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key=MYAPI&amp;callback=initialize;"/>

Это должно быть так:

<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key=MYAPI&amp;callback=initialize"/>

Попробуйте это на скрипке: http://jsfiddle.net/f74p69gz/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...