getCurrentPosition in JS does not work on iOS

后端 未结 4 868
孤街浪徒
孤街浪徒 2021-01-18 01:48

I have a page that contains a code that gets the current location from the device and load other stuff based on the location with this code:

if (navigator.ge         


        
相关标签:
4条回答
  • 2021-01-18 02:11

    You need to check three things

    Here's what we need to check:

    1. The user's OS has location services disabled.
    2. The user's browser has location services disabled.
    3. The user's browser doesn't support checking for location services at all.

    Combining the other answers on the page, we can handle all of these scenarios.

    This should get you up and running to handle all three scenarios:

        /* Set up getCurrentPosition options with a timeout */
        const navigatorLocationOptions = {
          enableHighAccuracy: true,
          timeout: 5000,
          maximumAge: 0
        };
    
        /* Determine browser permissions status */
        navigator.permissions.query({name:'geolocation'})
          .then((result) => {
            /* result.state will be 'granted', 'denied', or 'error' */
            if (result.state === 'granted') {
              navigator.geolocation.getCurrentPosition(pos => {
                 console.log('Retrieved user location', pos);
                 /* Got the location! Write your successful code here. */            
    
              }, (error) => {
                /* System/OS location services disabled */
                console.log('System/OS services disabled', navigator);
                noLocationFound();
              }, navigatorLocationOptions);
    
            } else {
              /* Browser location services disabled or error */
              console.log('Browser location services disabled', navigator);
              noLocationFound();
            }
          }, (error) => {
            /* Browser doesn't support querying for permissions */
            console.log('Browser permissions services unavailable', navigator);
            noLocationFound()
          });
    
          function noLocationFound() {
            /* Write code here for user location information is unavailable */
          }
    
    0 讨论(0)
  • 2021-01-18 02:17

    I just encountered the same issue. The simple answer is to ask the user, to give the permission to your browser in

    Settings > Privacy > Location Services.
    
    0 讨论(0)
  • 2021-01-18 02:19

    GeoLocation works only if a user provides his/her permissions.

    Make sure that is the case.

    This CodePen demo has been tested in iOS simulator with Safari and successfully shown the latitude and the longitude.

    var options = {
      enableHighAccuracy: true,
      timeout: 5000,
      maximumAge: 0
    };
    
    function log(data) {
      const tag = document.createElement('p');
      tag.textContent = data;
      document.body.appendChild(tag);
    }
    
    function success(pos) {
      var crd = pos.coords;
      console.log('Successfully determined a user position:', crd);
    
      log('Your current position is:');
      log(`Latitude : ${crd.latitude}`);
      log(`Longitude: ${crd.longitude}`);
      log(`More or less ${crd.accuracy} meters.`);
    }
    
    function error(err) {
      console.warn(`ERROR(${err.code}): ${err.message}`);
    }
    
    navigator.geolocation.getCurrentPosition(success, error, options);

    It can't be the case if your code doesn't hit either if nor else unless some other code has triggered an infinite loop earlier in your code.

    0 讨论(0)
  • 2021-01-18 02:27

    iOS and macOS doesn't give you the user's location if they don't allow it or if the system can not trust you. So:

    - First (Probably your answer)

    It works with the exact code you provided ONLY IF the host (aka the origin) is using https. That is the cause of permission alert not showing up due to your comment to an answer below.

    Remember if you not use https, it will be stuck for about a minute and then returns an error about authentication failure. Use error to check that:

    navigator.geolocation.getCurrentPosition(success, error, options)
    

    It will tell you something like this:

    [blocked] Access to geolocation was blocked over insecure connection to http://example.com.

    Tip: You can refresh the page after you requested the location to skip the waiting process. But don't forget to check the Preserve Log option in the inspector.

    - Second:

    If you are using https, then check your location settings for Safari, which might have been set to OFF somehow, you can change it here: Settings > Privacy > Location Services > Safari. This is not the default option, but maybe you changed it accidentally. So don't worry about the users if this was the issue. And if you use Chrome or any other third party browsers, head to its settings and check for location access. It's not there by default and appears only if location wanted at least once.

    - Third:

    If you are about to load your web inside an app using webView, make sure to add location permission descriptions to the info.plist file. Add NSLocationWhenInUseUsageDescription versus NSLocationAlwaysUsageDescription versus NSLocationUsageDescription as your needs.

    For the sake of completeness, on iOS13, you can not get always permission. But this is not the point here and the point is you have to get the required permissions sometime before you need to get the location from GPS or it is not going to work at all.

    0 讨论(0)
提交回复
热议问题