Can I detect if my PWA is launched as an app or visited as a website?

前端 未结 2 937
粉色の甜心
粉色の甜心 2021-02-04 16:24

If I have a PWA I might want to ask my user to add it to their launcher, but I don\'t want to ask this if it\'s actually launched from the launcher.

Is there any way to

相关标签:
2条回答
  • 2021-02-04 16:40

    For android, you should only prompt users to install after receiving a beforeinstallprompt event. This event will only be fired if the PWA has not already been installed.

    window.addEventListener('beforeinstallprompt', (e) => {
      e.preventDefault();
      deferredPrompt = e;
      // Update UI notify the user they can add to home screen
      btnAdd.style.display = 'block';
    });
    

    https://developers.google.com/web/fundamentals/app-install-banners/

    For IOS, you can check window.navigator.standalone, which should be true if the app has already been installed.

    // Detects if device is on iOS 
    const isIos = () => {
      const userAgent = window.navigator.userAgent.toLowerCase();
      return /iphone|ipad|ipod/.test( userAgent );
    }
    // Detects if device is in standalone mode
    const isInStandaloneMode = () => ('standalone' in window.navigator) && (window.navigator.standalone);
    
    // Checks if should display install popup notification:
    if (isIos() && !isInStandaloneMode()) {
      // offer app installation here
    }
    

    https://www.netguru.co/codestories/few-tips-that-will-make-your-pwa-on-ios-feel-like-native

    0 讨论(0)
  • 2021-02-04 16:47

    To put it in another way, you dont have to do any code to achieve this. Browser triggeres Install to home screen banner/related events, only if its used in a browser and wont happen from launcher.

    What you expect to do is the default behavior of how web install banners work.

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