1

我使用谷歌地图 js api 在我的联系页面中嵌入了谷歌地图。

我现在想做的就是当人们点击我的标记时,他们会去 maps.google.com 获取路线并查找更多信息。

    google.maps.event.addListener(marker, 'click', function () {
        window.open('http://goo.gl/muSZ5','_blank');
    });

那是我的代码,网址是 maps.google.com 的短网址,并添加了参数。

该脚本有效,但浏览器不会自动转到它打开的选项卡(因为它是由 javascript 触发器调用的)

有谁知道我该如何解决这个问题。

因此,单击标记,新窗口(选项卡)打开,自动转到该窗口(选项卡)

这是我的完整代码:

  (function ($) {
    Drupal.behaviors.location_block = {
        attach: function (context, settings) {
            console.log('test');
            var myOptions = {
                center: new google.maps.LatLng(50.87760,4.41923),
                zoom: 13,
                mapTypeId: google.maps.MapTypeId.ROADMAP,
                mapTypeControl: false
            };

            var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);

            var marker = new google.maps.Marker({
                position: new google.maps.LatLng(50.87760,4.41923),
                map: map,
                title: "Ilias",
                html: ""
            });

            google.maps.event.addListener(marker, 'click', function () {
                window.open('http://goo.gl/maps/L3rK','_blank');
            });
        }
    };
})(jQuery);

@EDIT @IMPORTANT 我发现问题仅在谷歌浏览器中,并且仅在我的网站中...

4

1 回答 1

0

它在我的机器上工作正常。请检查以下代码:

HTML 代码:

<script src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
<div id="map-canvas"></div>​

JS代码:

function initialize() {

    var myLatLng = new google.maps.LatLng( 50, 50 ),
        myOptions = {
            zoom: 4,
            center: myLatLng,
            mapTypeId: google.maps.MapTypeId.ROADMAP
            },
        map = new google.maps.Map( document.getElementById( 'map-canvas' ), myOptions ),
        marker = new google.maps.Marker( {position: myLatLng, map: map} );
    google.maps.event.addListener(marker, 'click', function () {
       window.open('http://goo.gl/muSZ5','_blank');
    });
    marker.setMap( map );

}

initialize();

​CSS 代码:

#map-canvas
{
height: 400px;
width: 500px;
}​

在线演示

于 2012-06-28T06:01:08.413 回答