为locationpicker.jquery.js设置当前用户位置

Setting Current User Location for locationpicker.jquery.js

本文关键字:用户 位置 设置 locationpicker jquery js      更新时间:2023-09-26

我正在使用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选择器放入纬度和经度的变量中。我尝试设置一个隐藏的输入字段,并将其传递到纬度和经度;但他们就是失败了。我能做些什么让位置选择器加载到用户的位置吗?纬度和经度似乎不接受除数字以外的任何其他类型的变量。

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

$( 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,
    ...
}

现在,getCurrentPosition()watchPosition()不再在不安全的起源上工作。要使用此功能,您应该考虑将应用程序切换到安全来源,例如HTTPS