简体   繁体   English

jQuery数据属性值丢失

[英]jQuery data attribute value missing

I have two data attributes in <option> , Which have the lat and lng for the map: 我在<option>有两个数据属性,它们分别具有地图的latlng

<option id="riderInfo" data-lat="" data-lng=""></option>

Jquery : jQuery的:

var lat = $("#riderInfo").val($(this).data('lat'));
var lng = $("#riderInfo").val($(this).data('lng'));

I am printing its value : 我正在打印其价值:

console.log(lat)

The actual code to get value from the select and give to the map, So map will chnage to the given location. 从选择中获取价值并提供给地图的实际代码,因此地图将更改为给定位置。

$(document).ready(function(){
  var lat = $("#riderInfo").val($(this).data('lat'));
  var lng = $("#riderInfo").val($(this).data('lng'));
  console.log(lat);

  google.maps.event.addDomListener(window, 'load', init);
  function init() {
     var locations = [
        ['Rider', 33.686073, 73.0175017, 3]
      ];
      var map = new google.maps.Map(document.getElementById('map'), {
        zoom: 10,
        center: new google.maps.LatLng(33.68, 73.01),
        mapTypeId: google.maps.MapTypeId.ROADMAP
      });
      var infowindow = new google.maps.InfoWindow();
      var marker, i;
      for (i = 0; i < locations.length; i++) {
        marker = new google.maps.Marker({
          position: new google.maps.LatLng(locations[i][1], locations[i][2]),
          map: map
        });
        google.maps.event.addListener(marker, 'click', (function(marker, i) {
          return function() {
            infowindow.setContent(locations[i][0]);
            infowindow.open(map, marker);
          }
        })(marker, i));
      }
  }
});

Result of console.log(lat) is : console.log(lat)结果是:

[option#riderInfo, context: document, selector: "#riderInfo"]

What am i missing ? 我想念什么?

By setting the value using jquery, jquery object of element is returned and set as variable. 通过使用jquery设置值,返回element的jquery对象并将其设置为变量。 you should be using: 您应该使用:

var lat = $('#riderInfo').data('lat');
var lng = $('#riderInfo').data('lng');

Here you go with a solution 在这里你有一个解决方案

 $(document).ready(function(){ var lat = parseFloat($("#riderInfo").data('lat')); var lng = parseFloat($("#riderInfo").data('lng')); console.log(lat); google.maps.event.addDomListener(window, 'load', init); function init() { var locations = [ ['Rider', lat, lng, 3] ]; var map = new google.maps.Map(document.getElementById('map'), { zoom: 10, center: new google.maps.LatLng(lat, lng), mapTypeId: google.maps.MapTypeId.ROADMAP }); var infowindow = new google.maps.InfoWindow(); var marker, i; for (i = 0; i < locations.length; i++) { marker = new google.maps.Marker({ position: new google.maps.LatLng(locations[i][1], locations[i][2]), map: map }); google.maps.event.addListener(marker, 'click', (function(marker, i) { return function() { infowindow.setContent(locations[i][0]); infowindow.open(map, marker); } })(marker, i)); } } }); 

Get the data values of lat , lng into the variable & use it in map function latlng的数据值获取到变量中并在map函数中使用

Hope this will help you. 希望这会帮助你。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM