私はJSが初めてで、以前の質問への答えを見つけました。それは新しい質問をもたらし、それが再び私をここに連れてきました。
Google Map APIを含むReveal Modalがあります。ボタンをクリックすると、Reveal Modalがポップアップ表示され、Googleマップが表示されます。私の問題は、マップの3分の1しか表示されていないことです。これは、サイズ変更トリガーを実装する必要があるためです。私の質問は、google.maps.event.trigger(map、 'resize')の実装方法です。この小さなコードスニペットはどこに配置しますか?
これが私のテストサイトです。 Googleマップボタンをクリックして、手元の問題を確認します。 http://simplicitdesignanddevelopment.com/Fannie%20E%20Zurb/foundation/contact_us.html#
Reveal Modelスクリプト:
_<script type="text/javascript">
$(document).ready(function() {
$('#myModal1').click(function() {
$('#myModal').reveal();
});
});
</script>
_
私のGoogleマップスクリプト:
_<script type="text/javascript">
function initialize() {
var mapOptions = {
center: new google.maps.LatLng(39.739318, -89.266507),
zoom: 5,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_canvas"),
mapOptions);
}
</script>
_
Googleマップを保持するdiv:
_ <div id="myModal" class="reveal-modal large">
<h2>How to get here</h2>
<div id="map_canvas" style="width:600px; height:300px;"></div>
<a class="close-reveal-modal">×</a>
</div>
_
UPDATE 2018-05-22
Maps JavaScript APIバージョン3.32の新しいレンダラーリリースでは、resizeイベントはMap
クラスの一部ではなくなりました。
ドキュメントの状態
マップのサイズが変更されると、マップの中心が固定されます
フルスクリーンコントロールが中心を保持するようになりました。
サイズ変更イベントを手動でトリガーする必要がなくなりました。
ソース: https://developers.google.com/maps/documentation/javascript/new-renderer
google.maps.event.trigger(map, "resize");
は、バージョン3.32以降では効果がありません
実際には、ソースコードにいくつかの問題がありました。
initialize()
関数は作成されますが、呼び出されることはありません$(document).ready
は、jQueryをロードした後に呼び出す必要がありますmap
は(@Cristiano Fontesが言ったように)グローバル変数であり、var map
ではありませんclick
イベントは呼び出されません。 2つのメソッドを組み合わせようとしています Zurbからの公開 は、ダイアログを開くために提供します(1つはJS、もう1つはHTMLのみ)。唯一のJSメソッドを使用する必要があります。#myModal1
がHTMLに配置されることはありません)。そして今: ソリューションをダウンロードする (次回ダウンロード/ JSFiddleを提供してください。これを自分で作成する必要はありません)。
お役に立てば幸いです!
ここに追加するだけです
<script type="text/javascript">
$(document).ready(function() {
$('#myModal1').click(function() {
$('#myModal').reveal();
google.maps.event.trigger(map, 'resize');
});
});
</script>
ただし、マップをグローバル変数として配置する必要があるため、ここで変数を失います
<script type="text/javascript">
function initialize() {
var mapOptions = {
center: new google.maps.LatLng(39.739318, -89.266507),
zoom: 5,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
--> map = new google.maps.Map(document.getElementById("map_canvas"),
mapOptions);
}
</script>
google.maps.event.addListenerOnce(map, 'tilesloaded', function() {
google.maps.event.addListenerOnce(map, 'tilesloaded', function() {
google.maps.event.trigger(map, 'resize');
});
});
最後の回答にコメントを残す方法が見つかりませんでしたが、クリスティアーノ・フォンテスの場合は+1が役立ちます!動いた。私の場合:
<script type="text/javascript">
$('div.map-box').hide();
$('li.map').mouseover(function(){
$('div.map-box').show();
google.maps.event.trigger(map, 'resize');
});
</script>