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/

आउटपुट कंसोल में दिखाया गया है।