आरएक्सजेएस - वेधशालाएं

एक अवलोकन एक ऐसा कार्य है जो एक पर्यवेक्षक बनाता है और इसे उस स्रोत से जोड़ता है जहां मूल्यों की अपेक्षा की जाती है, उदाहरण के लिए, एक मूल तत्व से माउस की घटनाओं या एक Http अनुरोध, आदि।

Observer is an object with callback functions, कि जब ऑब्जर्वेबल के साथ बातचीत होती है, तो उसे कॉल किया जाएगा, यानी, स्रोत ने एक उदाहरण बटन क्लिक, हेट्टी अनुरोध, आदि के लिए बातचीत की है।

हम इस अध्याय में निम्नलिखित विषयों पर चर्चा करने जा रहे हैं -

  • अवलोकनीय बनाएँ
  • अवलोकन योग्य है
  • अवलोकनीय अवलोकनीय

अवलोकनीय बनाएँ

अवलोकन योग्य कंस्ट्रक्टर का उपयोग करके और अवलोकन योग्य विधि का उपयोग करके बनाया जा सकता है और सदस्यता फ़ंक्शन को एक तर्क के रूप में पारित करके, जैसा कि नीचे दिखाया गया है -

testrx.js

import { Observable } from 'rxjs';

var observable = new Observable(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);

हमने एक अवलोकन योग्य बनाया है और "मेरा पहला अवलोकन" का उपयोग करके एक संदेश जोड़ा है subscriber.next वेधशाला के अंदर उपलब्ध विधि।

हम नीचे दिखाए गए अनुसार ऑब्जर्वेबल का उपयोग करके ऑब्जर्वेबल.क्रीट () विधि भी बना सकते हैं -

testrx.js

import { Observable } from 'rxjs';
var observer = Observable.create(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);

अवलोकन योग्य है

आप इस प्रकार एक अवलोकन योग्य सदस्यता ले सकते हैं -

testrx.js

import { Observable } from 'rxjs';

var observer = new Observable(
   function subscribe(subscriber) {
      subscriber.next("My First Observable")
   }
);
observer.subscribe(x => console.log(x));

जब पर्यवेक्षक को सदस्यता दी जाती है, तो यह ऑब्जर्वेबल का निष्पादन शुरू कर देगा।

यह हम ब्राउज़र कंसोल में देखते हैं -

अवलोकनीय अवलोकनीय

सब्सक्राइब होने पर एक अवलोकन योग्य हो जाता है। एक पर्यवेक्षक एक ऐसी विधि है जिसमें तीन तरीकों को अधिसूचित किया जाता है,

next() - इस विधि से संख्या, स्ट्रिंग, ऑब्जेक्ट आदि जैसे मान भेजे जाएंगे।

complete() - यह विधि किसी भी मूल्य को नहीं भेजती है और अवलोकन योग्य को पूरा होने का संकेत देती है।

error() - यह विधि यदि कोई हो तो त्रुटि भेज देगी।

आइए हम सभी तीन सूचनाओं के साथ अवलोकन करें और उसी को निष्पादित करें।

testrx.js

import { Observable } from 'rxjs';
var observer = new Observable(
   function subscribe(subscriber) {
      try {
         subscriber.next("My First Observable");
         subscriber.next("Testing Observable");
         subscriber.complete();
      } catch(e){
         subscriber.error(e);
      }
   }
);
observer.subscribe(x => console.log(x), (e)=>console.log(e), 
   ()=>console.log("Observable is complete"));

उपरोक्त कोड में, हमने अगला, पूर्ण और त्रुटि विधि जोड़ा है।

try{
   subscriber.next("My First Observable");
   subscriber.next("Testing Observable");
   subscriber.complete();
} catch(e){
   subscriber.error(e);
}

अगली, पूर्ण और त्रुटि को निष्पादित करने के लिए, हमें नीचे दिखाए अनुसार सदस्यता विधि को कॉल करना होगा -

observer.subscribe(x => console.log(x), (e)=>console.log(e), 
   ()=>console.log("Observable is complete"));

त्रुटि विधि केवल तभी दर्ज की जाएगी जब कोई त्रुटि हो।

यह ब्राउज़र में देखा गया आउटपुट है -