JavaScript मॉड्यूल बंडलर कई काम कर सकते हैं, लेकिन यह उनके सबसे ज़्यादा काम आने वाले कामों में से एक है सुविधाओं की मदद से, अपने कोड बेस में बाहरी लाइब्रेरी जोड़ी और इस्तेमाल की जा सकती हैं. मॉड्यूल बंडलर आपके कोड में इंपोर्ट पाथ को पढ़ते हैं और आपके आयात किए गए लाइब्रेरी कोड के साथ ऐप्लिकेशन-विशिष्ट कोड.
वर्शन 9 और उसके बाद वाले वर्शन से, Firebase JavaScript मॉड्यूलर एपीआई Google Analytics 4 प्रॉपर्टी के साथ काम करने के लिए ऑप्टिमाइज़ किया गया है. Firebase कोड की मात्रा कम करने के लिए, मॉड्यूल बंडलर की ऑप्टिमाइज़ेशन सुविधाएं यह आपके फ़ाइनल बिल्ड में शामिल है.
import { initializeApp } from 'firebase/app';
import { getAuth, onAuthStateChanged, getRedirectResult } from 'firebase/auth';
const firebaseApp = initializeApp({ /* config */ });
const auth = getAuth(firebaseApp);
onAuthStateChanged(auth, user => { /* check status */ });
/**
* getRedirectResult is unused and should not be included in the code base.
* In addition, there are many other functions within firebase/auth that are
* not imported and therefore should not be included as well.
*/
लाइब्रेरी से इस्तेमाल न किए गए कोड हटाने की इस प्रोसेस को पेड़ का हिलना कहा जाता है. इसे मैन्युअल तरीके से हटाने में बहुत ज़्यादा समय लगता है और गड़बड़ी हो सकती है कोड को मैन्युअल तौर पर जोड़ा जा सकता है, लेकिन मॉड्यूल बंडलर के पास इसे हटाने की प्रोसेस अपने-आप करने की सुविधा होती है.
JavaScript नेटवर्क में अच्छी क्वालिटी वाले कई मॉड्यूल बंडलर मौजूद हैं. यह गाइड में Firebase का इस्तेमाल करने के साथ-साथ, webpack, रोलअप, और esbuild.
शुरू करें
इस गाइड के लिए आपके डेवलपमेंट एनवायरमेंट में npm इंस्टॉल होना ज़रूरी है. डिपेंडेंसी (लाइब्रेरी) को इंस्टॉल और मैनेज करने के लिए, एनपीएम का इस्तेमाल किया जाता है. एनपीएम इंस्टॉल करने के लिए, Node.js इंस्टॉल करें, जिसमें npm स्वचालित रूप से चालू करें.
Node.js को इंस्टॉल करने के बाद, ज़्यादातर डेवलपर सही तरीके से सेट अप होते हैं. हालांकि, तो कई डेवलपर को अपना ऐप्लिकेशन सेट अप करते समय पर्यावरण को ध्यान में रखते हुए काम करना. अगर आपको कोई गड़बड़ी मिलती है, पक्का करें कि आपके एनवायरमेंट में एनपीएम सीएलआई हो आपके पास सही अनुमतियां सेट अप हों, ताकि आप sudo कमांड की मदद से, एडमिन के तौर पर पैकेज इंस्टॉल करने की ज़रूरत नहीं होती.
पैकेज.json और Firebase इंस्टॉल करना
npm इंस्टॉल करने के बाद आपको यहां एक package.json
फ़ाइल बनानी होगी
आपके लोकल प्रोजेक्ट का रूट है. इस फ़ाइल को इस npm कमांड के साथ जनरेट करें:
npm init
यह आपको ज़रूरी जानकारी देने के लिए एक विज़र्ड पर ले जाएगा. एक बार फ़ाइल बनाई जाती है, तो यह निम्न जैसी दिखाई देगी:
{
"name": "your-package-name",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {
}
}
यह फ़ाइल कई अलग-अलग चीज़ों के लिए ज़िम्मेदार है. Google आपका खाता मैनेज करने के लिए,
मॉड्यूल बंडलिंग और इसके बारे में ज़्यादा जानने के लिए,
में JavaScript कोड बनाना भी शामिल है. इस गाइड के लिए सबसे ज़रूरी बात यह है कि
"dependencies"
ऑब्जेक्ट. इस ऑब्जेक्ट में लाइब्रेरी का की-वैल्यू पेयर होगा
आपके द्वारा इंस्टॉल किया गया वर्शन और उसके द्वारा उपयोग किया जा रहा वर्शन.
डिपेंडेंसी जोड़ने के लिए, npm install
या npm i
निर्देश का इस्तेमाल किया जाता है.
npm i firebase
npm i firebase
चलाने पर, इंस्टॉल करने की प्रोसेस अपडेट हो जाएगी
Firebase को डिपेंडेंसी के तौर पर सूची में जोड़ने के लिए package.json
:
"dependencies": {
"firebase": "^9.0.0"
},
कुंजी, लाइब्रेरी का नाम होती है और वैल्यू का मतलब होता है इस्तेमाल किया जाने वाला वर्शन. कॉन्टेंट बनाने वर्शन का मान सुविधाजनक है और वह कई तरह की वैल्यू स्वीकार कर सकता है. इसे इस नाम से जाना जाता है: सिमैंटिक वर्शन या सेंवर. Semver के बारे में ज़्यादा जानने के लिए, सिमेंटिक वर्शन के बारे में एनपीएम की गाइड देखें.
सोर्स बनाम बिल्ड फ़ोल्डर
आपने जो कोड लिखा है उसे मॉड्यूल बंडलर की मदद से पढ़ा और प्रोसेस किया जाता है. इसके बाद, नई फ़ाइल या फ़ाइलों का सेट. इन दो तरह की फ़ाइलों को अलग करना ज़रूरी है. मॉड्यूल बंडलर जिस कोड को पढ़ते हैं और प्रोसेस करते हैं उसे "सोर्स" कहा जाता है कोड. कॉन्टेंट बनाने ऐसी फ़ाइलें जिन्हें आउटपुट किया जाता है उन्हें 'बिल्ट' या ''डिस्टेंस'' के तौर पर जाना जाता है (डिस्ट्रिब्यूशन) कोड.
कोड बेस में एक सामान्य सेटअप सोर्स कोड को src
नाम के फ़ोल्डर में स्टोर करना होता है
और बिल्ट कोड dist
नाम के फ़ोल्डर में मौजूद है.
- src
|_ index.js
|_ animations.js
|_ datalist.js
- dist
|_ bundle.js
ऊपर दी गई फ़ाइल स्ट्रक्चर के उदाहरण में, ध्यान दें कि index.js
, दोनों को इंपोर्ट करता है
animations.js
और datalist.js
. जब कोई मॉड्यूल बंडलर सोर्स को प्रोसेस करता है
कोड सेट करेगा, यह bundle.js
फ़ाइल को dist
फ़ोल्डर में बनाएगा. bundle.js
src
फ़ोल्डर में मौजूद फ़ाइलों और इंपोर्ट की गई लाइब्रेरी का कॉम्बिनेशन है
भी.
यदि आप Git जैसे स्रोत नियंत्रण सिस्टम का उपयोग कर रहे हैं, तो
मुख्य डेटा स्टोर करने की जगह में इस कोड को सेव करने के दौरान dist
फ़ोल्डर.
एंट्री पॉइंट
सभी मॉड्यूल बंडलर में एंट्री पॉइंट का कॉन्सेप्ट होता है. आप सोच सकते हैं कि अनुप्रयोग को फ़ाइलों के ट्री के रूप में रखना चाहिए. एक फ़ाइल दूसरी फ़ाइल से कोड इंपोर्ट करती है और इसी तरह अन्य आगे भी देख सकें. इसका मतलब है कि एक फ़ाइल ट्री का रूट होगी. यह फ़ाइल है को एंट्री पॉइंट कहते हैं.
चलिए, फ़ाइल स्ट्रक्चर के पिछले उदाहरण पर फिर से गौर करते हैं.
- src
|_ index.js
|_ animations.js
|_ datalist.js
- dist
|_ bundle.js
// src/index.js
import { animate } from './animations';
import { createList } from './datalist';
// This is not real code, but for example purposes only
const theList = createList('users/123/tasks');
theList.addEventListener('loaded', event => {
animate(theList);
});
src/index.js
फ़ाइल को एंट्री पॉइंट माना जाता है, क्योंकि यह
ऐप्लिकेशन के लिए सभी ज़रूरी कोड को इंपोर्ट करता है. यह एंट्री पॉइंट फ़ाइल है
इसका इस्तेमाल मॉड्यूल बंडलर, बंडल करने की प्रोसेस शुरू करने के लिए करता है.
webpack के साथ Firebase का इस्तेमाल करना
Firebase ऐप्लिकेशन और Webpack के लिए किसी खास कॉन्फ़िगरेशन की ज़रूरत नहीं है. यह सेक्शन में सामान्य वेबपैक कॉन्फ़िगरेशन शामिल है.
इसके लिए सबसे पहले, वेबपैक को एनपीएम से डेवलपमेंट डिपेंडेंसी के तौर पर इंस्टॉल करें.
npm i webpack webpack-cli -D
अपने लोकल प्रोजेक्ट के रूट में webpack.config.js
नाम की फ़ाइल बनाएं और
नीचे दिया गया कोड जोड़ें.
const path = require('path');
module.exports = {
// The entry point file described above
entry: './src/index.js',
// The location of the build folder described above
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'bundle.js'
},
// Optional and for development only. This provides the ability to
// map the built code back to the original source format when debugging.
devtool: 'eval-source-map',
};
इसके बाद, पक्का करें कि आपने Firebase को डिपेंडेंसी के तौर पर इंस्टॉल किया हो.
npm i firebase
इसके बाद, अपने कोड बेस में Firebase शुरू करें. यह कोड इंपोर्ट और एंट्री पॉइंट फ़ाइल में Firebase शुरू करता है और "शहर" दस्तावेज़.
// src/index.js
import { initializeApp } from 'firebase/app';
import { getFirestore, doc, getDoc } from 'firebase/firestore/lite';
const firebaseApp = initializeApp({ /* config */ });
const db = getFirestore(firebaseApp);
async function loadCity(name) {
const cityDoc = doc(db, `cities/${name}`);
const snapshot = await getDoc(cityDoc);
return {
id: snapshot.id,
...snapshot.data(),
};
}
अगला कदम है एनपीएम स्क्रिप्ट जोड़ना
ताकि वेबपैक बिल्ड चलाया जा सके. package.json
फ़ाइल खोलें
और यहां दिए गए 'की वैल्यू पेयर' को "scripts"
ऑब्जेक्ट में जोड़ें.
"scripts": {
"build": "webpack --mode=development"
},
webpack चलाने और बिल्ड फ़ोल्डर जनरेट करने के लिए, नीचे दिया गया निर्देश चलाएं.
npm run build
आखिर में, dist
बिल्ड फ़ोल्डर देखें. इसमें
bundle.js
, जिसमें आपका बंडल किया गया ऐप्लिकेशन और डिपेंडेंसी कोड है.
अपने वेबपैक बिल्ड को प्रोडक्शन के लिए ऑप्टिमाइज़ करने के बारे में ज़्यादा जानकारी के लिए, "mode" पर आधिकारिक दस्तावेज़ कॉन्फ़िगरेशन सेटिंग है.
रोलअप के साथ Firebase का इस्तेमाल करना
Firebase ऐप्लिकेशन और रोलअप टूल के लिए, किसी खास कॉन्फ़िगरेशन की ज़रूरत नहीं है. यह सेक्शन में एक सामान्य रोलअप कॉन्फ़िगरेशन शामिल है.
सबसे पहले, रोलअप टूल और एक ऐसा प्लगिन इंस्टॉल करें जिसका इस्तेमाल इंपोर्ट को मैप करने के लिए किया जाता है डिपेंडेंसी को npm के साथ इंस्टॉल किया जाता है.
npm i rollup @rollup/plugin-node-resolve -D
rollup.config.js
नाम के अपने लोकल प्रोजेक्ट के रूट में एक फ़ाइल बनाएं और जोड़ें
है.
import { nodeResolve } from '@rollup/plugin-node-resolve';
export default {
// the entry point file described above
input: 'src/index.js',
// the output for the build folder described above
output: {
file: 'dist/bundle.js',
// Optional and for development only. This provides the ability to
// map the built code back to the original source format when debugging.
sourcemap: 'inline',
// Configure Rollup to convert your module code to a scoped function
// that "immediate invokes". See the Rollup documentation for more
// information: https://rollupjs.org/guide/en/#outputformat
format: 'iife'
},
// Add the plugin to map import paths to dependencies
// installed with npm
plugins: [nodeResolve()]
};
इसके बाद, अपने कोड बेस में Firebase शुरू करें. यह कोड इंपोर्ट और एंट्री पॉइंट फ़ाइल में Firebase शुरू करता है और "शहर" दस्तावेज़.
// src/index.js
import { initializeApp } from 'firebase/app';
import { getFirestore, doc, getDoc } from 'firebase/firestore/lite';
const firebaseApp = initializeApp({ /* config */ });
const db = getFirestore(firebaseApp);
async function loadCity(name) {
const cityDoc = doc(db, `cities/${name}`);
const snapshot = await getDoc(cityDoc);
return {
id: snapshot.id,
...snapshot.data(),
};
}
अगला कदम है एनपीएम स्क्रिप्ट जोड़ना
का इस्तेमाल करें. package.json
फ़ाइल खोलें
और यहां दिए गए 'की वैल्यू पेयर' को "scripts"
ऑब्जेक्ट में जोड़ें.
"scripts": {
"build": "rollup -c rollup.config.js"
},
रोलअप चलाने और बिल्ड फ़ोल्डर जनरेट करने के लिए, यह निर्देश चलाएं.
npm run build
आखिर में, dist
बिल्ड फ़ोल्डर देखें. इसमें
bundle.js
, जिसमें आपका बंडल किया गया ऐप्लिकेशन और डिपेंडेंसी कोड है.
अपने रोलअप बिल्ड को प्रोडक्शन के लिए ऑप्टिमाइज़ करने के बारे में ज़्यादा जानकारी के लिए, प्रोडक्शन बिल्ड के लिए प्लगिन के बारे में आधिकारिक दस्तावेज़.
esbuild के साथ Firebase का इस्तेमाल करना
Firebase ऐप्लिकेशन और esbuild के लिए किसी खास कॉन्फ़िगरेशन की ज़रूरत नहीं है. यह सेक्शन में एक सामान्य esbuild कॉन्फ़िगरेशन शामिल किया गया है.
सबसे पहले, esbuild को डेवलपमेंट डिपेंडेंसी के तौर पर इंस्टॉल करें.
npm i esbuild -D
अपने लोकल प्रोजेक्ट के रूट में esbuild.config.js
नाम की फ़ाइल बनाएं और
नीचे दिया गया कोड जोड़ें.
require('esbuild').build({
// the entry point file described above
entryPoints: ['src/index.js'],
// the build folder location described above
outfile: 'dist/bundle.js',
bundle: true,
// Replace with the browser versions you need to target
target: ['chrome60', 'firefox60', 'safari11', 'edge20'],
// Optional and for development only. This provides the ability to
// map the built code back to the original source format when debugging.
sourcemap: 'inline',
}).catch(() => process.exit(1))
इसके बाद, अपने कोड बेस में Firebase शुरू करें. यह कोड इंपोर्ट और एंट्री पॉइंट फ़ाइल में Firebase शुरू करता है और "शहर" दस्तावेज़.
// src/index.js
import { initializeApp } from 'firebase/app';
import { getFirestore, doc, getDoc } from 'firebase/firestore/lite';
const firebaseApp = initializeApp({ /* config */ });
const db = getFirestore(firebaseApp);
async function loadCity(name) {
const cityDoc = doc(db, `cities/${name}`);
const snapshot = await getDoc(cityDoc);
return {
id: snapshot.id,
...snapshot.data(),
};
}
अगला कदम है एनपीएम स्क्रिप्ट जोड़ना
esbuild चलाने के लिए. package.json
फ़ाइल खोलें और जोड़ें
"scripts"
ऑब्जेक्ट के साथ नीचे दी गई कुंजी वैल्यू का जोड़ा.
"scripts": {
"build": "node ./esbuild.config.js"
},
आखिर में, dist
बिल्ड फ़ोल्डर देखें. इसमें
bundle.js
, जिसमें आपका बंडल किया गया ऐप्लिकेशन और डिपेंडेंसी कोड है.
प्रोडक्शन के लिए esbuild को ऑप्टिमाइज़ करने के बारे में ज़्यादा जानकारी के लिए, संबंधित दस्तावेज़ देखें छोटा करने और अन्य ऑप्टिमाइज़ेशन के बारे में दस्तावेज़.