jquery - 使用 jQuery 单击按钮加载 Google map

标签 jquery google-maps

我目前正在尝试根据单击的 anchor 标记来更改屏幕上显示的 map 。纬度和经度存储在名为“data-latLng”的 anchor 标记上的 HTML 属性中,并传递到我的 Javascript,然后使用此 latLng 向 Google API 发出请求。

我遇到的问题是实际 map 没有显示。缩放栏和其他功能显示良好。这只是实际的 map 本身。 我创建了一个 jFiddle 来显示我的代码。 我在这件事上走得正确吗? 谢谢

http://jsfiddle.net/fJdtY/

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
        html { height: 100% }
        body { height: 100%; margin: 0; padding: 0 }
        #map-canvas { height: 100% }
    </style>
    <script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
    <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key={KEY_HIDDEN}&sensor=false">
    </script>       
</head>
<body>
    <a href="#" class="button" data-latLng="53.488188,-2.373019">Button</a>
    <a href="#" class="button" data-latLng="-34.397, 150.644">Button 2</a>
    <div id="map-canvas"></div>
</body>

<script type="text/javascript">
jQuery(document).ready(function() {
    jQuery(document).on("click", ".button", function(e) {
        e.preventDefault();
        var latLng = jQuery(this).attr("data-latLng");          
        initialize(latLng);
    });

    function initialize(latLng) {
        var mapOptions = {
            center: new google.maps.LatLng(latLng),
            zoom: 8
        };
        var map = new google.maps.Map(document.getElementById("map-canvas"), mapOptions);
    }
}); 

最佳答案

仅分割 latLng 效果非常好。

function initialize(latLng) {
    latLng = latLng.split(",") //split
    var mapOptions = {
        center: new google.maps.LatLng(latLng[0],latLng[1]), //assign Seprately
        zoom: 8
    };
    var map = new google.maps.Map(document.getElementById("map-canvas"), mapOptions);
}
}); 

JS FIDDLE:- http://jsfiddle.net/fJdtY/2/

关于jquery - 使用 jQuery 单击按钮加载 Google map ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23404763/

相关文章:

javascript - Angular Google map 地理编码回调

javascript - "return false"在某些浏览器中被忽略,因为链接使用 JavaScript 动态添加到 DOM

javascript - 悬停从 jquery 到 Backbone 代码

jquery焦点问题

java - 我自己的应用程序中两个位置之间的谷歌地图行车路线

android - 使用 volley 获取位置数据并在 Google map 中创建多个标记

java - 使用谷歌静态 map - JFrame 或 Javascript

jquery - 如何选择列表中除一个命名项之外的所有元素

jQuery attr href,为什么它不起作用?

jquery - 使用jQuery加载元素会影响SEO排名吗?