Firebase JavaScript SDK टूल के साथ काम करने वाले एनवायरमेंट

साथ काम करने वाले एनवायरमेंट

Firebase JavaScript SDK टूल, आधिकारिक तौर पर इन एनवायरमेंट में काम करता है.

ब्राउज़र

Firebase प्रॉडक्ट Edge Firefox Chrome iOS Safari Safari
App Check
Analytics
Authentication
Cloud Firestore
(
परसिस्टेंस को छोड़कर)

(iOS 10 से पहले के वर्शन के लिए,
परसिस्टेंस
को छोड़कर)
Cloud Functions
Firebase इंस्टॉल
Cloud Messaging
(मोबाइल को छोड़कर, Edge 17 और उसके बाद के वर्शन)
Cloud Storage
Performance Monitoring
Realtime Database
Remote Config
Vertex AI in Firebase

अन्य एनवायरमेंट

Firebase प्रॉडक्ट नेटिव लेआउट में प्रतिक्रिया दें Node.js (18+) Chrome
एक्सटेंशन
Cordova
App Check
(डिवाइस से प्रमाणित करने के लिए, सेवा देने वाली किसी कंपनी का इस्तेमाल करना)

(कस्टम प्रोवाइडर का इस्तेमाल करके)
Analytics
Authentication
(ध्यान दें देखें)

(ध्यान दें देखें)

(ध्यान दें देखें)

(ध्यान दें देखें)
Cloud Firestore
(
परसिस्टेंस को छोड़कर)

(निरंतरता
के अलावा)
Cloud Functions
Firebase इंस्टॉल
Cloud Messaging
Cloud Storage
(
अपलोड को छोड़कर)
Performance Monitoring
Realtime Database
Remote Config
Vertex AI in Firebase

पॉलीफ़िल

Firebase JavaScript SDK टूल, वेब प्लैटफ़ॉर्म के नए स्टैंडर्ड पर बनाया गया है. कुछ पुराने ब्राउज़र और JavaScript एनवायरमेंट में, Firebase की ज़रूरी सभी सुविधाएं काम नहीं करतीं. अगर आपको इन ब्राउज़र/एनवायरमेंट के साथ काम करना है, तो आपको पॉलीफ़िल को उसके हिसाब से लोड करना होगा.

यहां दिए गए सेक्शन में, ज़्यादातर ऐसे पॉलीफ़िल के बारे में बताया गया है जिनकी आपको ज़रूरत पड़ सकती है.

ज़रूरी पॉलीफ़िल

एनवायरमेंट पॉलीफ़िल
Safari 7, 8, और 9 ES Stable
नोड की संख्या 10 से कम हो ES Stable

वैकल्पिक polyfills

एनवायरमेंट पॉलीफ़िल Firebase प्रॉडक्ट
  • Safari 10.1 से पहले के वर्शन
  • iOS 10.3 से पहले के वर्शन
फ़ेच करें
  • Authentication
  • Cloud Firestore
  • Cloud Functions
  • Performance Monitoring
  • नोड < 18
फ़ेच करें
  • Authentication
  • Cloud Firestore
  • Cloud Functions
  • Cloud Storage
  • React Native और Expo
base-64
  • Cloud Storage

सुझाए गए पॉलीफ़िल

पॉलीफ़िल लाइसेंस
ES स्थिर MIT
fetch - `cross-fetch` - पुराने ब्राउज़र के लिए सबसे अच्छा MIT
फ़ेच - `undici` - Node.js के लिए सबसे अच्छा MIT
बेस-64 MIT

React Native और Expo के लिए ज़रूरी पॉलीफ़िल सेटअप

React Native और Expo के लिए, अगर आपको base-64 कोड में बदली गई स्ट्रिंग अपलोड करनी है, तो आपको ये काम करने होंगे:

base-64 को npm से इंस्टॉल करें:

npm install base-64

base-64 से decode इंपोर्ट करें और उसे ग्लोबल स्कोप में atob के तौर पर अटैच करें, ताकि Cloud Storage उसे ऐक्सेस कर सके.

import { decode } from 'base-64';

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

अपने ऐप्लिकेशन में पॉलीफ़िल जोड़ना

पहला विकल्प: (सुझाया गया) Babel के साथ इंटिग्रेट किए गए बंडलर का इस्तेमाल करना

अगर बंडलर का इस्तेमाल किया जा रहा है, तो Babel और @babel/preset-env के साथ इंटिग्रेट करें, ताकि आप polyfills पा सकें.

Babel को अपने बंडलर के साथ इंटिग्रेट करने का तरीका जानने के लिए, Babel की इंटरैक्टिव सेटअप गाइड का इस्तेमाल करें.

बेबल के साथ, आपको यह चिंता करने की ज़रूरत नहीं है कि पूरी तरह से पॉलीफ़िल को शामिल किया जाना है. इसके बजाय, आपको उन ब्राउज़र एनवायरमेंट के बारे में बताना होगा जिन पर आपको अपने ऐप्लिकेशन को चलाना है. इसके बाद, Babel आपके लिए ज़रूरी पॉलीफ़िल जोड़ता है. Babel यह पक्का करता है कि ब्राउज़र के साथ काम करने की आपकी ज़रूरी शर्तें हमेशा पूरी होती रहें. भले ही, Firebase या आपका कोड, ES की नई सुविधाओं का इस्तेमाल शुरू कर दे.

@babel/preset-env में, एनवायरमेंट टारगेट (targets विकल्प) तय करने और पॉलीफ़िल (useBuiltIns विकल्प) जोड़ने के लिए, कॉन्फ़िगरेशन के उपलब्ध विकल्पों के बारे में पूरी जानकारी दी गई है.

दूसरा विकल्प: (इसका सुझाव नहीं दिया जाता) मैन्युअल तरीके से पॉलीफ़िल जोड़ना

अपनी पसंदीदा पॉलीफ़िल लाइब्रेरी (उदाहरण के लिए, core-js) का इस्तेमाल करके, पॉलीफ़िल को मैन्युअल तरीके से जोड़ा जा सकता है.

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

core-js, सभी-एक-साथ-काम करने वाली polyfill फ़ाइल भी उपलब्ध कराता है. इसे सीधे एचटीएमएल पेज में शामिल किया जा सकता है.

अगर Babel का इस्तेमाल नहीं किया जा रहा है, तो यह विकल्प, पॉलीफ़िल को मैनेज करने का एक आसान तरीका हो सकता है. हालांकि, हम प्रोडक्शन ऐप्लिकेशन के लिए, एक ही जगह पर सभी सुविधाएं देने वाले इस विकल्प का सुझाव नहीं देते. इसकी वजह यह है कि इसमें ज़रूरत से ज़्यादा पॉलीफ़िल शामिल हो सकते हैं. इससे पेज का साइज़ बढ़ जाता है और पेज लोड होने में ज़्यादा समय लगता है.