नॉकआउट जेएस - कम्प्यूटेड ऑब्जर्वबल्स

कंप्यूटेड ऑब्जर्वेबल एक फ़ंक्शन है जो एक या एक से अधिक ऑब्जर्वबल्स पर निर्भर है और जब भी इसके अंतर्निहित ऑब्जर्वल्स (निर्भरताएं) बदलते हैं तो स्वचालित रूप से अपडेट होते हैं।

गणना की गई वेधशालाएँ जंजीर हो सकती हैं।

वाक्य - विन्यास

this.varName = ko.computed(function(){
   ...
   ... //  function code
   ...
},this);

उदाहरण

आइए हम निम्नलिखित उदाहरण देखें जो कम्प्यूटेड ऑब्जर्वबल्स के उपयोग को प्रदर्शित करता है।

<!DOCTYPE html>
   <head >
      <title>KnockoutJS Computed Observables</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.1.0.js"></script>
   </head>

   <body>
      <p>Enter first number: <input data-bind = "value: a" /></p>
      <p>Enter second number: <input data-bind = "value: b"/></p>
      <p>Average := <span data-bind="text: totalAvg"></span></p>

      <script>
         function MyViewModel() {
            this.a = ko.observable(10);
            this.b = ko.observable(40);

            this.totalAvg = ko.computed(function() {

               if(typeof(this.a()) !== "number" || typeof(this.b()) !== "number") {
                  this.a(Number(this.a()));   //convert string to Number
                  this.b(Number(this.b()));   //convert string to Number
               }

               total = (this.a() + this.b())/2 ;
               return total;
            },this);
         }

         ko.applyBindings(new MyViewModel());
      </script>

   </body>
</html>

निम्नलिखित पंक्तियों में, पहले दो इनपुट मानों को स्वीकार करने के लिए हैं। तीसरी पंक्ति इन दो नंबरों के औसत को प्रिंट करती है।

<p>Enter first number: <input data-bind = "value: a" /></p>
<p>Enter second number: <input data-bind = "value: b"/></p>
<p>Average := <span data-bind = "text: totalAvg"></span></p>

निम्नलिखित पंक्तियों में, वेधशाला के प्रकार a तथा bनंबर है जब वे ViewModel के अंदर पहली बार आरंभीकृत होते हैं। हालाँकि, KO में UI से स्वीकृत प्रत्येक इनपुट स्ट्रिंग प्रारूप में डिफ़ॉल्ट रूप से होता है। इसलिए उन्हें संख्या में परिवर्तित करने की आवश्यकता है ताकि उन पर अंकगणितीय ऑपरेशन किया जा सके।

this.totalAvg = ko.computed(function() {
   
   if(typeof(this.a()) !== "number" || typeof(this.b()) !== "number") {
      this.a(Number(this.a()));   //convert string to Number
      this.b(Number(this.b()));   //convert string to Number
   }
   
   total = (this.a() + this.b())/2 ;
   return total;
},this);

निम्न पंक्ति में, परिकलित औसत UI में प्रदर्शित होता है। ध्यान दें कि टोटल एवीजी का डेटा-बाइंड प्रकार केवल पाठ है।

<p>Average := <span data-bind = "text: totalAvg"></span></p>

उत्पादन

उपरोक्त कोड कैसे काम करता है, यह देखने के लिए निम्नलिखित कदम उठाएँ -

  • में उपरोक्त कोड सहेजें computed-observable.htm फ़ाइल।

  • इस HTML फाइल को ब्राउजर में खोलें।

  • टेक्स्ट बॉक्स में कोई भी 2 नंबर दर्ज करें और देखें कि औसत की गणना की गई है।

'यह' का प्रबंधन

ध्यान दें कि उपरोक्त उदाहरण में, दूसरा पैरामीटर प्रदान किया गया है thisकम्प्यूटेड फ़ंक्शन के लिए। वेधशालाओं को संदर्भित करना संभव नहीं हैa() तथा b() प्रदान किए बिना this

इसे दूर करने के लिए, self चर का उपयोग किया जाता है जो का संदर्भ रखता है this। ऐसा करने से, ट्रैक करने की कोई आवश्यकता नहीं हैthisपूरे कोड में। बजाय,self इस्तेमाल किया जा सकता है।

ViewModel कोड को निम्न उदाहरण के लिए स्व का उपयोग करके फिर से लिखा गया है।

function MyViewModel(){
   self = this;
   self.a = ko.observable(10);
   self.b = ko.observable(40);

   this.totalAvg = ko.computed(function() {
      
      if(typeof(self.a()) !== "number" || typeof(self.b()) !== "number") {
         self.a(Number(self.a()));   //convert string to Number
         self.b(Number(self.b()));   //convert string to Number
      }
      
      total = (self.a() + self.b())/2 ;
      return total;
   });
}

शुद्ध संगणक वेधशालाएँ

एक कंप्यूटेड ऑब्जर्वेबल के रूप में घोषित किया जाना चाहिए Pureकंप्यूटेड ऑब्जर्वेबल अगर वह ऑब्जर्वेबल बस गणना कर रहा है और मूल्य वापस कर रहा है और अन्य वस्तुओं या राज्य को सीधे संशोधित नहीं कर रहा है। शुद्ध गणना की गई वेधशालाएँ पुनर्मूल्यांकन और स्मृति उपयोग को कुशलता से प्रबंधित करने के लिए नॉकआउट में मदद करती हैं।

ग्राहकों को स्पष्ट रूप से सूचित करना

जब एक कम्प्यूटेशनल ऑब्जर्वेबल आदिम डेटा टाइप वैल्यू (स्ट्रिंग, बूलियन, नल और नंबर) वापस कर रहा होता है तो उसके सब्सक्राइबर्स को सूचित किया जाता है कि क्या और केवल तभी वास्तविक वैल्यू में बदलाव होता है। इसका मतलब है कि यदि किसी पर्यवेक्षक को पिछले मूल्य के समान मूल्य प्राप्त हुआ है, तो उसके ग्राहकों को सूचित नहीं किया जाता है।

आप गणना किए गए वेधशालाओं को हमेशा पर्यवेक्षकों को स्पष्ट रूप से सूचित कर सकते हैं, भले ही नया मान पुराने का उपयोग करने के समान हो notify सिंटैक्स निम्नानुसार है।

myViewModel.property = ko.pureComputed(function() {
   return ...;    // code logic goes here
}).extend({ notify: 'always' });

परिवर्तन सूचनाएं सीमित करना

बहुत से महंगे अपडेट के परिणामस्वरूप प्रदर्शन समस्याएँ हो सकती हैं। आप अवलोकन योग्य उपयोग से प्राप्त होने वाली सूचनाओं की संख्या को सीमित कर सकते हैंrateLimit विशेषता निम्नानुसार है।

// make sure there are updates no more than once per 100-millisecond period
myViewModel.property.extend({ rateLimit: 100 });

यह पता लगाना कि क्या कोई संपत्ति अभिकलन योग्य है

कुछ स्थितियों में, यह पता लगाना आवश्यक हो सकता है कि क्या कोई संपत्ति एक कंप्यूटेड ऑब्जर्वेबल है। निम्नलिखित कार्यों का उपयोग वेधशालाओं के प्रकारों की पहचान करने के लिए किया जा सकता है।

अनु क्रमांक। समारोह
1

ko.isComputed

रिटर्न true अगर संपत्ति कम्प्यूटेड ऑब्जर्वेबल है।

2

ko.isObservable

रिटर्न true यदि संपत्ति अवलोकनीय है, अवलोकनीय सरणी या संगणित अवलोकनीय है।

3

ko.isWritableObservable

रिटर्न trueअगर अवलोकनीय, अवलोकनीय सरणी, या लिखने योग्य अभिप्रेरित अवलोकनीय है। (इसे ko.isWriteableObservable भी कहा जाता है)

लिखित कम्प्यूटरीकृत वेधशालाएं

कंप्यूटेड ऑब्जर्वेबल को एक या एक से अधिक ऑब्जर्वबल्स से लिया जाता है, इसलिए इसे केवल पढ़ा जाता है। हालांकि, यह संभव है कि कोई कंप्यूटेड ऑब्जर्वेबल लेखन योग्य बना सके। इसके लिए आपको कॉलबैक फ़ंक्शन प्रदान करना होगा जो लिखित मूल्यों पर काम करता है।

ये लेखन योग्य कम्प्यूटरीकृत वेधशालाएँ नियमित वेधशालाओं की तरह ही काम करती हैं। इसके अलावा, उन्हें पढ़ने और लिखने की क्रियाओं में हस्तक्षेप करने के लिए कस्टम लॉजिक की आवश्यकता होती है।

एक कई वेधशालाओं या कंप्यूटेड ऑब्जर्व करने योग्य गुणों के मानों को निम्न प्रकार से चाइनिंग सिंटैक्स का उपयोग करके असाइन कर सकते हैं।

myViewModel.fullName('Tom Smith').age(45)

उदाहरण

उदाहरण के बाद, लिखने योग्य कम्प्यूटेबल अवलोकन के उपयोग को प्रदर्शित करता है।

<!DOCTYPE html>
   <head >
      <title>KnockoutJS Writable Computed Observable</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"></script>
   </head>

   <body>
      <p>Enter your birth Date: <input type = "date" data-bind = "value: rawDate" ></p>
      <p><span data-bind = "text: yourAge"></span></p>

      <script>
         function MyViewModel() {
            this.yourAge = ko.observable();
            today = new Date();
            rawDate = ko.observable();

            this.rawDate = ko.pureComputed ({

               read: function() {
                  return this.yourAge;
               },

               write: function(value) {
                  var b = Date.parse(value);    // convert birth date into milliseconds
                  var t = Date.parse(today);    // convert todays date into milliseconds
                  diff = t - b;                 // take difference
                  var y = Math.floor(diff/31449600000);     // difference is converted
                                                            // into years. 31449600000
                                                            //milliseconds form a year.

                  var m = Math.floor((diff % 31449600000)/604800000/4.3);  // calculating
                                                                           // months.
                                                                           // 604800000
                                                                           // milliseconds
                                                                           // form a week.

                  this.yourAge("You are " + y + " year(s) " + m +" months old.");
               },
               owner: this
            });
         }

         ko.applyBindings(new MyViewModel());
      </script>

   </body>
</html>

उपरोक्त कोड में, rawDate UI से स्वीकार की गई शुद्ध संपत्ति है। yourAge अवलोकनीय है rawDate

जावास्क्रिप्ट में तिथियों को मिलीसेकेंड में हेरफेर किया जाता है। इसलिए, दोनों तिथियों (आज की तारीख और जन्म तिथि) को मिलीसेकंड में बदल दिया जाता है और फिर उनके बीच का अंतर वर्षों और महीनों में वापस बदल दिया जाता है।

उत्पादन

उपरोक्त कोड कैसे काम करता है, यह देखने के लिए निम्नलिखित कदम उठाएँ -

  • में उपरोक्त कोड सहेजें writable_computed_observable.htm फ़ाइल।

  • इस HTML फाइल को ब्राउजर में खोलें।

  • किसी भी जन्म तिथि को दर्ज करें और देखें कि आयु की गणना की गई है।