티스토리 뷰

데스크탑에서 크롬이나 모바일 안드로이드 같은 경우 beforeinstallpropmt 이벤트를 사용해서 다운로드 버튼을 만들 수 있지만 ios는 작성일 기준까지도 불가능하다. 

 

1. beforeinstallpropmt 이벤트 등록하기

import React, { useEffect, useRef } from "react";

...

let deferredPrompt = useRef(null);

useEffect(() => {
    console.log("Listening for Install prompt");
    window.addEventListener("beforeinstallprompt", (e) => {
      e.preventDefault();
      deferredPrompt.current = e;
    });
    
    //설치가 되어있다면 버튼은 숨긴다
    if (!deferredPrompt.current) {
      return dispatch({
        type: "HIDE_BUTTON",
      });
    }

//버튼을 보여줌
    dispatch({
      type: "SHOW_BUTTON",
    });
  }, []);
  
  ...

useRef를 사용하여 defferdpropmt변수에 beforeinstallpropmt 이벤트를 넣는다

 

2. 설치 함수 만들기

const installApp = () => {
    if (!deferredPrompt.current) return false;
    
    //홈화면의 추가를 실행시킨다
    deferredPrompt.current.prompt();
    
    //실행 후 유저가 설치를 했는지 안했는지를 알 수 있다
    deferredPrompt.current.userChoice.then((choiceResult) => {
      //설치 했을 때
      if (choiceResult.outcome === "accepted") {
        console.log("User accepted the A2HS prompt");
        dispatch({
          type: "HIDE_BUTTON",
        });
      } else {
      //설치 하지 않았을 때
        console.log("User dismissed the A2HS prompt");
      }
    });
  };

 

3.버튼에 이벤트 등록

...

return (
  <>
    <button onClick={installApp}>다운로드</button>
  </>
);

 

next js에 pwa 적용하기 : https://jcon.tistory.com/171

반응형

'Nextjs' 카테고리의 다른 글

next js에 pwa 적용하기  (0) 2020.08.07
next + pwa 홈화면에 추가 버튼 생성  (0) 2020.05.28
next + pwa 설정  (0) 2020.05.28
Next js 튜토리얼 8편 : 배포  (0) 2019.10.10
Next js 튜토리얼 7편 : 컴포넌트 스타일링  (0) 2019.10.05
댓글