Firebase 자바스크립트 SDK가 지원되는 환경

지원되는 환경

Firebase 자바스크립트 SDK는 공식적으로 다음 환경에서 지원됩니다.

브라우저

Firebase 제품 에지 Firefox Chrome iOS Safari Safari
앱 체크
애널리틱스
인증
Cloud Firestore
(지속성
제외)

(iOS 10 미만인 경우
지속성
제외)
Cloud Functions
Firebase 설치
클라우드 메시징
(Edge 17 이상, 모바일 제외)
Cloud Storage
Performance Monitoring
실시간 데이터베이스
원격 구성

기타 환경

Firebase 제품 React Native Node.js Chrome
확장 프로그램
Cordova
앱 체크
(맞춤 제공자를 사용하여 네이티브 기기 증명 실행)

(맞춤 제공업체 사용)
애널리틱스
인증
(참고 참조)

(참고 참조)

(참고 참조)

(참고 참조)
Cloud Firestore
(지속성
제외)

(지속성
제외)
Cloud Functions
Firebase 설치
클라우드 메시징
Cloud Storage
(업로드
제외)
Performance Monitoring
실시간 데이터베이스
원격 구성

Polyfill

Firebase 자바스크립트 SDK는 최신 웹 플랫폼 표준을 기반으로 빌드되었습니다. 일부 오래된 버전의 브라우저와 자바스크립트 환경에서는 Firebase에 필요한 기능을 모두 지원하지는 않습니다. 오래된 브라우저와 환경을 지원해야 하는 경우 polyfill을 적절하게 로드해야 합니다.

로드해야 할 대부분의 polyfill이 아래 섹션에 나와 있습니다.

필수 polyfill

환경 Polyfill
Safari 7, 8, 9 ES 지원
Node 6.5 이전 버전 ES 지원

선택사항 polyfill

환경 Polyfill Firebase 제품
  • 노드
  • Safari 10.1 이전 버전
  • iOS 10.3 이전 버전
가져오기
  • Cloud Functions
  • Performance Monitoring
  • React Native 및 Expo
base-64
  • Cloud Storage

추천 polyfill

Polyfill 라이선스
ES 지원 MIT
가져오기 MIT
base-64 MIT

React Native 및 Expo에 필요한 Polyfill 설정

base64로 인코딩된 문자열을 업로드할 때 React Native 및 Expo의 경우 다음을 실행해야 합니다.

npm에서 base-64를 설치합니다.

npm install base-64

Cloud Storage가 액세스할 수 있도록 base-64에서 decode를 가져와서 전역 범위에 atob로 연결합니다.

import { decode } from 'base-64';

if(typeof atob === 'undefined') {
  global.atob = decode;
}

애플리케이션에 polyfill 추가

옵션 1: (권장) Bundler를 Babel과 통합하여 사용

Bundler를 사용하는 경우 Babel@babel/preset-env를 통합하여 polyfill을 가져옵니다.

Babel과 bundler를 통합하는 방법은 Babel의 대화형 설정 가이드를 참조하세요.

Babel을 사용하면 포함할 polyfill이 정확히 무엇인지 고민하지 않아도 됩니다. 지원해야 할 최소 버전의 브라우저 환경만 지정하면 Babel이 필요한 polyfill을 자동으로 추가해줍니다. Babel을 사용하면 Firebase나 자체 코드에서 새로운 ES 기능을 사용하는 경우에도 브라우저 지원 요구사항이 항상 충족됩니다.

@babel/preset-env에는 환경 대상을 지정(옵션 targets)하고 polyfill을 추가(옵션 useBuiltIns)하는 구성 옵션에 대한 자세한 정보가 포함되어 있습니다.

옵션 2: (권장되지 않음) 수동으로 polyfill 추가

즐겨찾는 polyfill 라이브러리(예: core-js)를 사용하여 수동으로 polyfill을 추가할 수 있습니다.

import 'core-js/stable'
import 'cross-fetch/polyfill';

core-js는 HTML 페이지에 직접 포함할 수 있는 통합 polyfill 파일도 제공합니다.

이 옵션을 사용하면 Babel을 사용하지 않을 때도 polyfill을 편리하게 관리할 수 있습니다. 하지만 이 통합 옵션을 사용할 경우 불필요한 polyfill이 포함되어 페이지가 무거워지고 페이지 로딩 시간이 길어질 수 있으므로 프로덕션 앱에서는 사용하지 않는 것이 좋습니다.