クリックしたときにボタンが表示され、このコード行を含むブートストラップモーダルにhtmlファイルを読み込みます。googlemaps javascriptが2回ロードされないようにする
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyAbePUCw9D44HfcTuiWyFQs_HbQ_6Qw-fA&signed_in=true&libraries=places&callback=initMap"
async defer></script>
このエラーが発生しました。
このページにはGoogle Maps APIが複数回含まれています。予期しないエラーが発生する可能性があります。
どのようにgooglemapsスクリプトが2回読み込まれるのを防ぐには?ここで
私のコードは
<div class="modal fade" id="trackMapModal" role="dialog"></div>
<button class='pull-right track' id="2"><strong>Track it!</strong></button>
<script>
$("#trackMapModal").appendTo("body");
$(".track").click(function(){
var id = this.id;
$.ajax({
type:"POST",
url:"<?=base_url("/track/viewMap")?>",
dataType:"html",
data: {id : id},
success:function(res){
$("#trackMapModal").html(res).modal("show");
}
})
});
</script>
とトラック/ viewMapそれはスクリプトがinitMap()関数を実行するコールバックを持つことになります。このスクリプト
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyAbePUCw9D44HfcTuiWyFQs_HbQ_6Qw-fA&signed_in=true&libraries=places&callback=initMap"
async defer></script>
があるマップを返します/ですロードされたとき。
/トラック/ viewMapコードという名前のビューに
function viewMap(){
$id = $this->input->post("id,true);
$data["id"]=$id;
$data["loc"]["dest"]=array("lat"=>51.1124587,"lng"=>42.1245457);
$this->load->view("/MAIN/mapModal",$data);
}
/MAIN/mapModal
<div id="map"></div>
<script>
function initMap() {
var directionsService = new google.maps.DirectionsService;
var directionsDisplay = new google.maps.DirectionsRenderer;
var marker2;
var map = new google.maps.Map(document.getElementById('map'),{
center: {lat: <?=$loc["lat"]?>, lng: <?=$loc["lng"]?>},zoom:17
});
marker2 = new google.maps.Marker({
position: myLatlng,
map: map
});
marker2.setMap(map);
}
</script>
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyAbePUCw9D44HfcTuiWyFQs_HbQ_6Qw-fA&signed_in=true&libraries=places&callback=initMap" async defer></script>
は二回、それをロードしないでください..あなたのコードの詳細が表示されていない限り、 – evolutionxbox
私はこのような質問がupvotedまだ良いクエストを得る方法を理解していない完全なコードを持つイオンは、 – Pete
downmapされているiframeにHTMLページを読み込んでいますか? –