Google地图初始化不能与标签一起使用 [英] Google map initialize not working with tab

查看:92
本文介绍了Google地图初始化不能与标签一起使用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我试图初始化Google Map的标签点击事件,因为目前我正在像这样获取地图:



我的代码:

 (function($){

/ *
* render_map
*
*函数将渲染一个Google Map到选定的jQuery元素
*
* @type函数
* @date 8/11/2013
* @since 4.3.0
*
* @param $ el(jQuery元素)
* @return不适用
* /

函数render_map($ el){

// var
var $ markers = $ el.find('。marker');

//变量
var args = {
zoom: 16,
center:new google.maps.LatLng(0,0),
mapTypeId:google.maps.MapTypeId.ROADMAP
};

//创建map
var map = new google.maps.Map($ el [0],args);

// a dd a marker reference
map.markers = [];
$ b $ //添加记号
$ markers.each(函数(){

add_marker($(this),map);

});

//中心地图
center_map(地图);

}

/ *
* add_marker
*
*此功能会为选定的Google地图
添加一个标记*
* @type函数
* @date 8/11/2013
* @since 4.3.0
*
* @param $ marker(jQuery元素)
* @param map(Google Map对象)
* @return不适用
* /

函数add_marker($ marker,map){

// var
var latlng = new google.maps.LatLng($ marker.attr('data-lat'),$ marker.attr('data-lng'));

//创建标记
var marker = new google.maps.Marker({
position:latlng,
map:map
});

//添加到数组
map.markers.push(marker);

//如果marker包含HTML,将它添加到infoWindow
if($ marker.html())
{
//创建信息窗口
var infowindow = new google.maps.InfoWindow({
content:$ marker.html()
});

//点击标记时显示信息窗口
google.maps.event.addListener(marker,'click',function(){

infowindow.open (map,marker);

});
}

}

/ *
* center_map
*
*此功能将使地图居中,显示所有标记附加到此地图
*
* @type函数
* @date 8/11/2013
* @since 4.3.0
*
* @ param map(Google Map object)
* @return n / a
* /

function center_map(map){
$ b // vars
var bounds = new google.maps.LatLngBounds();

//遍历所有标记并创建边界
$ .each(map.markers,function(i,marker){

var latlng = new google。 maps.LatLng(marker.position.lat(),marker.position.lng());

bounds.extend(latlng);

});

//只有1个标记?
if(map.markers.length == 1)
{
//设置地图中心
map.setCenter(bounds.getCenter());
map.setZoom(16);
}
else
{
//符合界限
map.fitBounds(bounds);
}

}

/ *
*文档准备好
*
*此函数将在文档已准备就绪(页面已加载)
*
* @type函数
* @date 2013年8月8日
* @since 5.0.0
*
* @param n / a
* @return n / a
* /

$(document).ready(function(){

$('。acf-map')。each(function(){

render_map($(this));

});

});

})(jQuery);

我尝试过使用此代码,但无法使用:


$ b $

  $(.map).click(function(){

google.maps.event.trigger map,'resize');
map.setCenter(center);

});


解决方案

var map = new google.maps.Map($ el [0],args); //局部作用于render_map($ el)

1)map变量不是全局声明的 p>

因此,当您尝试执行下面的代码时,您将遇到错误。

  google.maps.event.trigger(map,'resize'); 
map.setCenter(center);
});



尝试#1



尝试更改 map 作为全局变量。



尝试#2



将它作为委托事件处理程序,并将以下代码添加到 render_map($ el)方法中。

  $(document).on('click','.map',function(){
google.maps.event .trigger(map,'resize');
map.setCenter(center);
});


I am trying to initialize Google Map on tab click event because currently I am getting map like this:

My Code:

(function($) {

/*
*  render_map
*
*  This function will render a Google Map onto the selected jQuery element
*
*  @type    function
*  @date    8/11/2013
*  @since   4.3.0
*
*  @param   $el (jQuery element)
*  @return  n/a
*/

function render_map( $el ) {

    // var
    var $markers = $el.find('.marker');

    // vars
    var args = {
        zoom        : 16,
        center      : new google.maps.LatLng(0, 0),
        mapTypeId   : google.maps.MapTypeId.ROADMAP
    };

    // create map               
    var map = new google.maps.Map( $el[0], args);

    // add a markers reference
    map.markers = [];

    // add markers
    $markers.each(function(){

        add_marker( $(this), map );

    });

    // center map
    center_map( map );

}

/*
*  add_marker
*
*  This function will add a marker to the selected Google Map
*
*  @type    function
*  @date    8/11/2013
*  @since   4.3.0
*
*  @param   $marker (jQuery element)
*  @param   map (Google Map object)
*  @return  n/a
*/

function add_marker( $marker, map ) {

    // var
    var latlng = new google.maps.LatLng( $marker.attr('data-lat'), $marker.attr('data-lng') );

    // create marker
    var marker = new google.maps.Marker({
        position    : latlng,
        map         : map
    });

    // add to array
    map.markers.push( marker );

    // if marker contains HTML, add it to an infoWindow
    if( $marker.html() )
    {
        // create info window
        var infowindow = new google.maps.InfoWindow({
            content     : $marker.html()
        });

        // show info window when marker is clicked
        google.maps.event.addListener(marker, 'click', function() {

            infowindow.open( map, marker );

        });
    }

}

/*
*  center_map
*
*  This function will center the map, showing all markers attached to this map
*
*  @type    function
*  @date    8/11/2013
*  @since   4.3.0
*
*  @param   map (Google Map object)
*  @return  n/a
*/

function center_map( map ) {

    // vars
    var bounds = new google.maps.LatLngBounds();

    // loop through all markers and create bounds
    $.each( map.markers, function( i, marker ){

        var latlng = new google.maps.LatLng( marker.position.lat(), marker.position.lng() );

        bounds.extend( latlng );

    });

    // only 1 marker?
    if( map.markers.length == 1 )
    {
        // set center of map
        map.setCenter( bounds.getCenter() );
        map.setZoom( 16 );
    }
    else
    {
        // fit to bounds
        map.fitBounds( bounds );
    }

}

/*
*  document ready
*
*  This function will render each map when the document is ready (page has loaded)
*
*  @type    function
*  @date    8/11/2013
*  @since   5.0.0
*
*  @param   n/a
*  @return  n/a
*/

$(document).ready(function(){

    $('.acf-map').each(function(){

        render_map( $(this) );

    });

});

})(jQuery);

I have tried with this code but not worked:

$( ".map" ).click(function() {

    google.maps.event.trigger(map, 'resize');
    map.setCenter(center);

});

解决方案

var map = new google.maps.Map( $el[0], args); //locally scoped in render_map($el)

1) map variable is not globally declared.

So when you try to execute this below code, you will suffer an error.

$( ".map" ).click(function() {
    google.maps.event.trigger(map, 'resize');
    map.setCenter(center);
});

Try #1

Try to change map as global variable.

Try #2

Make it as a delegate event handler and add the below code to render_map( $el ) method.

$(document).on('click', '.map', function() {
    google.maps.event.trigger(map, 'resize');
    map.setCenter(center);
});

这篇关于Google地图初始化不能与标签一起使用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆