RxJS - पर्यावरण सेटअप
इस अध्याय में, हम RxJS स्थापित करने जा रहे हैं। RxJS के साथ काम करने के लिए, हमें निम्नलिखित सेटअप की आवश्यकता है -
- NodeJS
- Npm
- RxJS पैकेज स्थापना
NODEJS और NPM इंस्टॉलेशन
Npm का उपयोग करके RxJS को स्थापित करना बहुत आसान है। आपको अपने सिस्टम पर नोडज और एनपीएम स्थापित करने की आवश्यकता है। यह सत्यापित करने के लिए कि आपके सिस्टम पर NodeJS और npm स्थापित है, अपने कमांड प्रॉम्प्ट में निम्न कमांड निष्पादित करने का प्रयास करें।
E:\>node -v && npm -v
v10.15.1
6.4.1
यदि आप संस्करण प्राप्त कर रहे हैं, तो इसका मतलब है कि नोडज और एनपीएम आपके सिस्टम पर स्थापित है और सिस्टम पर अभी संस्करण 10 और 6 है।
यदि यह कुछ भी प्रिंट नहीं करता है, तो अपने सिस्टम पर नोडज स्थापित करें। नोडज स्थापित करने के लिए, होमपेज पर जाएंhttps://nodejs.org/en/download/ अपने ओएस के आधार पर पैकेज को स्थापित करें।
नोडज का डाउनलोड पृष्ठ निम्नलिखित की तरह दिखेगा -
अपने ओएस के आधार पर, आवश्यक पैकेज स्थापित करें। एक बार नोडज स्थापित होने के बाद, एनपीएम भी इसके साथ स्थापित किया जाएगा। यह जाँचने के लिए कि npm स्थापित है या नहीं, टर्मिनल में npm -v टाइप करें। यह npm के संस्करण को प्रदर्शित करना चाहिए।
RxJS पैकेज स्थापना
आरएक्सजेएस इंस्टॉलेशन के साथ शुरू करने के लिए, पहले एक फोल्डर बनाएं, जिसे बुलाया जाए rxjsproj/ जहां हम सभी RxJS उदाहरणों का अभ्यास करेंगे।
एक बार फोल्डर rxjsproj/ बनाया गया है, कमांड चलाएँ npm init, नीचे दिखाए गए प्रोजेक्ट सेटअप के लिए
E:\>mkdir rxjsproj
E:\>cd rxjsproj
E:\rxjsproj>npm init
Npm initकमांड निष्पादन के दौरान कुछ सवाल पूछेगा, बस एंटर दबाएं और आगे बढ़ें। एक बार एनपीएम init का निष्पादन हो जाने के बाद, यह निर्माण करेगाpackage.json अंदर rxjsproj / जैसा कि नीचे दिखाया गया है -
rxjsproj/
package.json
अब आप कमांड के नीचे rxjs स्थापित कर सकते हैं -
npm install ---save-dev rxjs
E:\rxjsproj>npm install --save-dev rxjs
npm notice created a lockfile as package-lock.json. You should commit this file.
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
+ [email protected]
added 2 packages from 7 contributors and audited 2 packages in 21.89s
found 0 vulnerabilities
हम RxJS स्थापना के साथ किया जाता है। आइए अब RxJS का उपयोग करने का प्रयास करें, इसके लिए एक फ़ोल्डर बनाएँsrc/ के भीतर rxjsproj/
तो, अब, हमारे पास फ़ोल्डर संरचना होगी जैसा कि नीचे दिखाया गया है -
rxjsproj/
node_modules/
src/
package.json
के भीतर src/ एक फ़ाइल बनाएँ testrx.js, और निम्नलिखित कोड लिखें -
testrx.js
import { of } from 'rxjs;
import { map } from 'rxjs/operators';
map(x => x * x)(of(1, 2, 3)).subscribe((v) => console.log(`Output is: ${v}`));
जब हम कमांड प्रॉम्प्ट में उपरोक्त कोड को कमांड का उपयोग करते हुए निष्पादित करते हैं - node testrx.js, यह आयात के लिए त्रुटि प्रदर्शित करेगा, क्योंकि नोडज को पता नहीं है कि आयात के साथ क्या करना है।
नोडज के साथ आयात कार्य करने के लिए, हमें नीचे दिखाए गए अनुसार npm का उपयोग करके ES6 मॉड्यूल पैकेज स्थापित करने की आवश्यकता है -
E:\rxjsproj\src>npm install --save-dev esm
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
+ [email protected]
added 1 package from 1 contributor and audited 3 packages in 9.32s
found 0 vulnerabilities
पैकेज स्थापित होने के बाद, अब हम निष्पादित कर सकते हैं testrx.js नीचे दिखाए अनुसार फ़ाइल -
E:\rxjsproj\src>node -r esm testrx.js
Output is: 1
Output is: 4
Output is: 9
हम आउटपुट को अभी देख सकते हैं, जो दिखाता है कि आरएक्सजेएस स्थापित है और उपयोग के लिए तैयार है। उपरोक्त विधि कमांड लाइन में RxJS का परीक्षण करने में हमारी मदद करेगी। यदि आप ब्राउज़र में RxJS का परीक्षण करना चाहते हैं, तो हमें कुछ अतिरिक्त पैकेजों की आवश्यकता होगी।
ब्राउज़र में RxJS का परीक्षण
Rxjsproj / फ़ोल्डर के अंदर निम्नलिखित पैकेज स्थापित करें -
npm install --save-dev babel-loader @babel/core @babel/preset-env webpack webpack-cli webpack-dev-server
E:\rxjsproj>npm install --save-dev babel-loader
@babel/core @babel/preset-env webpack webpack-cli webpack-dev-server
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: [email protected]
(node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@
1.2.9: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})
+ [email protected]
+ [email protected]
+ @babel/[email protected]
+ @babel/[email protected]
+ [email protected]
+ [email protected]
added 675 packages from 373 contributors and audited 10225 packages in 255.567s
found 0 vulnerabilities
हमारे Html फ़ाइल को निष्पादित करने के लिए सर्वर शुरू करने के लिए, हम वेबपैक-सर्वर का उपयोग करेंगे। Package.json में "पब्लिश" कमांड से हमें शुरुआत करने में मदद मिलेगी और साथ ही साथ सभी js फाइलों को वेबपैक का उपयोग करने में मदद मिलेगी। पैक्ड js फाइलें जो हमारी अंतिम js फाइल हैं उनका उपयोग पथ / देव फ़ोल्डर में सहेजा गया है ।
वेबपैक का उपयोग करने के लिए, हमें चलाने की आवश्यकता है npm run publish कमांड और कमांड को पैकेज में जोड़ा गया है। नीचे दिखाए अनुसार -
Package.json
{
"name": "rxjsproj",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"publish":"webpack && webpack-dev-server --output-public=/dev/",
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"devDependencies": {
"@babel/core": "^7.6.0",
"@babel/preset-env": "^7.6.0",
"babel-loader": "^8.0.6",
"esm": "^3.2.25",
"rxjs": "^6.5.3",
"webpack": "^4.39.3",
"webpack-cli": "^3.3.8",
"webpack-dev-server": "^3.8.0"
}
}
वेबपैक के साथ काम करने के लिए हमें पहले webpack.config.js नामक एक फाइल बनानी होगी, जिसमें वेबपैक के काम करने के लिए विन्यास विवरण हो।
फाइल का विवरण इस प्रकार है -
var path = require('path');
module.exports = {
entry: {
app: './src/testrx.js'
},
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
mode:'development',
module: {
rules: [
{
test:/\.(js)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['@babel/preset-env']
}
}
]
}
};
फ़ाइल की संरचना ऊपर बताई गई है। यह एक पथ से शुरू होता है जो वर्तमान पथ का विवरण देता है।
var path = require('path'); //gives the current path
अगला मॉड्यूल.एक्सपोर्ट ऑब्जेक्ट है जिसमें गुण प्रविष्टि, आउटपुट और मॉड्यूल है। प्रवेश प्रारंभ बिंदु है। यहां, हमें स्टार्ट जेएस फाइल देने की जरूरत है जिसे हम संकलित करना चाहते हैं।
entry: {
app: './src/testrx.js'
},
path.resolve (_dirname, 'src / testrx.js') - निर्देशिका में src फ़ोल्डर और उस फ़ोल्डर में testrx.js के लिए दिखेगा।
उत्पादन
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
आउटपुट पथ और फ़ाइल नाम विवरण के साथ एक ऑब्जेक्ट है ।पथ उस फ़ोल्डर को रखेगा जिसमें संकलित फ़ाइल रखी जाएगी और फ़ाइल नाम आपकी .html फ़ाइल में उपयोग की जाने वाली अंतिम फ़ाइल का नाम बताएगा।
मापांक
module: {
rules: [
{
test:/\.(js)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['@babel/preset-env']
}
}
]
}
Moduleनियम विवरण के साथ ऑब्जेक्ट है जिसमें गुण हैं अर्थात परीक्षण, शामिल, लोडर, क्वेरी। परीक्षण .js और .jsx के साथ समाप्त होने वाली सभी js फ़ाइल का विवरण रखेगा। इसमें वह पैटर्न है जो दिए गए प्रविष्टि बिंदु में अंत में .js के लिए दिखेगा।
Include फ़ाइलों को देखने के लिए उपयोग किए जाने वाले फ़ोल्डर को बताता है।
The loader कोड संकलन के लिए बेबल-लोडर का उपयोग करता है।
The queryप्रॉपर्टी प्रीसेट है, जो '@ babel / प्रीसेट-एनवी' मान के साथ एक सरणी है। यह उस ES वातावरण के अनुसार कोड को ट्रांसप्लेंट करेगा जिसे आपको जरूरत है।
अंतिम फ़ोल्डर संरचना निम्नानुसार होगी -
rxjsproj/
node_modules/
src/
testrx.js
index.html
package.json
webpack.config.js
चलाने के आदेश
npm run publishइसमें main_bundle.js फ़ाइल के साथ dev / folder बनाएंगे। सर्वर शुरू हो जाएगा और आप नीचे दिखाए गए अनुसार ब्राउज़र में अपने index.html का परीक्षण कर सकते हैं।
ब्राउज़र खोलें और url को हिट करें - http://localhost:8080/
आउटपुट कंसोल में दिखाया गया है।