我正在使用 locationpicker.jquery.js 并且我试图在加载之前提供经度和纬度的变量,以便用户可以从他或她的特定位置加载。

  $('.map').locationpicker({
      location: {
          latitude: 10.621760,
          longitude: 121.107015
      },
      radius: 10,
      inputBinding: {
          latitudeInput: $('.map-lat'),
          longitudeInput: $('.map-lon'),
          radiusInput: $('.map-radius'),
          locationNameInput: $('.map-address'),
          scrollwheel: true
      },
      enableReverseGeocode: true
  });

  $( document ).ready(function() {
      navigator.geolocation.getCurrentPosition(showPosition);
      function showPosition(position) {
          $('.map-lat').val(position.coords.latitude);
          $('.map-lon').val(position.coords.longitude);
      }
  });

我尝试将 jquery 选择器放入纬度和经度的变量中。我尝试设置一个隐藏的输入字段并将它们传递给纬度和经度;但他们只是失败了。我可以做些什么来使 locationpicker 在用户的位置加载?纬度和经度似乎不接受数字以外的任何其他类型的变量。

最佳答案

我认为您遇到的问题是 getCurrentLocation 是一个异步过程。这意味着您需要在该过程完成后加载 map 。

$( document ).ready(function() {
  navigator.geolocation.getCurrentPosition(showPosition);
  function showPosition(position) {
      var lat = position.coords.latitude;
      var lng = position.coords.longitude;
      $('.map-lat').val(lat);
      $('.map-lon').val(lng);
      buildMap(lat, lng);
  }
});

传入 latlng 参数并将它们转换为浮点数 (+lat ...),否则使用默认值。
function buildMap(lat, lng) {
  $('.map').locationpicker({
    location: {
      latitude: +lat || 10.621760,
      longitude: +lng || 121.107015
    },
    radius: 10,
    ...
}

关于javascript - 为 locationpicker.jquery.js 设置当前用户位置,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34329840/

10-12 03:33