नॉकआउट जेएस - वेधशालाएं
नॉकआउट जेएस निम्नलिखित 3 महत्वपूर्ण अवधारणाओं पर निर्मित है।
वेधशाला और उनके बीच निर्भरता ट्रैकिंग - DOM तत्व 'डेटा-बाइंड' के माध्यम से ViewModel से जुड़े हैं। वे वेधशालाओं के माध्यम से सूचनाओं का आदान-प्रदान करते हैं। यह स्वचालित रूप से निर्भरता ट्रैकिंग का ख्याल रखता है।
UI और ViewModel के बीच घोषणात्मक बाइंडिंग - DOM तत्व 'डेटा-बाइंड' अवधारणा के माध्यम से ViewModel से जुड़े हैं।
पुन: उपयोग करने योग्य घटकों को बनाने के लिए अस्थायी - अस्थायी वेब जटिल अनुप्रयोगों को बनाने का एक मजबूत तरीका प्रदान करता है।
हम इस अध्याय में वेधशालाओं का अध्ययन करेंगे।
जैसा कि नाम निर्दिष्ट करता है, जब आप ViewModel डेटा / प्रॉपर्टी को ऑब्जर्वेबल घोषित करते हैं, तो डेटा के उपयोग किए जाने वाले स्थानों पर हर बार कोई भी डेटा संशोधन स्वचालित रूप से परिलक्षित होता है। इसमें संबंधित निर्भरताओं को ताज़ा करना भी शामिल है। केओ इन बातों का ध्यान रखता है और इसे प्राप्त करने के लिए अतिरिक्त कोड लिखने की आवश्यकता नहीं है।
ऑब्जर्वेबल का उपयोग करके, UI और ViewModel को गतिशील रूप से बनाना बहुत आसान हो जाता है।
वाक्य - विन्यास
आपको बस फ़ंक्शन के साथ ViewModel संपत्ति घोषित करने की आवश्यकता है ko.observable() इसे देखने योग्य बनाने के लिए।
this.property = ko.observable('value');
उदाहरण
आइए निम्नलिखित उदाहरण पर एक नज़र डालें जो ऑब्जर्वेबल के उपयोग को दर्शाता है।
<!DOCTYPE html>
<head>
<title>KnockoutJS Observable Example</title>
<script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.1.0.js"
type = "text/javascript"></script>
</head>
<body>
<!-- This is called "view" of HTML markup that defines the appearance of UI -->
<p>Enter your name: <input data-bind = "value: yourName" /></p>
<p>Hi <strong data-bind = "text: yourName"></strong> Good Morning!!!</p>
<script>
<!-- This is called "viewmodel". This javascript section defines the data and behavior of UI -->
function AppViewModel() {
this.yourName = ko.observable("");
}
// Activates knockout.js
ko.applyBindings(new AppViewModel());
</script>
</body>
</html>
निम्न पंक्ति इनपुट बॉक्स के लिए है। जैसा कि देखा जा सकता है, हमने आपके नाम मान को ViewModel से बाँधने के लिए डेटा-बाइंड विशेषता का उपयोग किया है।
<p>Enter your name: <input data-bind = "value: yourName" /> <p>
निम्न पंक्ति आपके नाम का मान छापती है। ध्यान दें, यहाँ डेटा-बाइंड प्रकार वह पाठ है जैसा कि हम केवल मान पढ़ रहे हैं।
<p>Hi <strong data-bind = "text: yourName"></strong> Good Morning!!!</p>
निम्न पंक्ति में, ko.observable डेटा में किसी भी संशोधन के लिए आपके नाम चर पर नज़र रखता है। एक बार संशोधन होने के बाद, संबंधित स्थान भी संशोधित मूल्य के साथ अपडेट हो जाते हैं। जब आप निम्न कोड चलाते हैं, तो एक इनपुट बॉक्स दिखाई देगा। जब और जब आप उस इनपुट बॉक्स को अपडेट करते हैं, तो नया मान उन जगहों पर परिलक्षित या ताज़ा हो जाएगा जहाँ इसका उपयोग किया जाता है।
this.yourName = ko.observable("");
उत्पादन
उपरोक्त कोड कैसे काम करता है, यह देखने के लिए निम्नलिखित कदम उठाएँ -
में उपरोक्त कोड सहेजें first_observable_pgm.htm फ़ाइल।
इस HTML फाइल को ब्राउजर में खोलें।
नाम को स्कॉट के रूप में दर्ज करें और निरीक्षण करें कि नाम आउटपुट में परिलक्षित होता है।
डेटा संशोधन UI से या ViewModel से हो सकता है। चाहे जहाँ से डेटा बदला जाए, यूआई और व्यूमॉडल उनके बीच तालमेल बनाए रखता है। यह इसे दो-तरफा-बाध्यकारी तंत्र बनाता है। उपरोक्त उदाहरण में, जब आप इनपुट बॉक्स में अपना नाम बदलते हैं, तो ViewModel को एक नया मान मिलता है। जब आप ViewModel के अंदर से अपनी नाम संपत्ति बदलते हैं, तो UI एक नया मान प्राप्त करता है।
वेधशालाओं को पढ़ना और लिखना
निम्नलिखित तालिका सूचियों को पढ़ती है और लिखती है जिसे वेधशालाओं पर किया जा सकता है।
अनु क्रमांक। | पढ़ें / लिखें ऑपरेशन और सिंटैक्स |
---|---|
1 | Read मान पढ़ने के लिए, मापदंडों के बिना केवल अवलोकन योग्य संपत्ति को कॉल करें: AppViewModel.yourName (); |
2 | Write अवलोकन योग्य संपत्ति में मूल्य लिखने / अपडेट करने के लिए, बस पैरामीटर में वांछित मान पास करें जैसे: AppViewModel.yourName ('बॉब'); |
3 | Write multiple मल्टीपल व्यूमॉडल गुणों को एक पंक्ति में चेंजिंग-सिंटैक्स की मदद से अपडेट किया जा सकता है, जैसे: AppViewModel.yourName ('बॉब')। आपका (45); |
अवलोकनीय अर्र
अवलोकन योग्य घोषणा एकल वस्तु के डेटा संशोधनों का ध्यान रखती है। ऑब्जर्वेबलएरे वस्तुओं के संग्रह के साथ काम करता है। यह एक बहुत ही उपयोगी विशेषता है जब आप कई प्रकार के मूल्यों वाले जटिल अनुप्रयोगों से निपट रहे हैं और उपयोगकर्ता कार्यों के आधार पर अक्सर अपनी स्थिति बदल रहे हैं।
वाक्य - विन्यास
this.arrayName = ko.observableArray(); // It's an empty array
अवलोकनीय सरणी केवल ट्रैक करती है कि इसमें कौन सी वस्तुएँ जोड़ी या निकाली गई हैं। यह सूचित नहीं करता है कि क्या व्यक्तिगत ऑब्जेक्ट के गुणों को संशोधित किया गया है।
पहली बार में इसे शुरू करें
आप अपने एरे को इनिशियलाइज़ कर सकते हैं और साथ ही आप कंस्ट्रक्टर को प्रारंभिक मान निम्नानुसार पास करके इसे ऑब्जर्वेबल घोषित कर सकते हैं।
this.arrayName = ko.observableArray(['scott','jack']);
अवलोकनीय सरणी से पढ़ना
आप निम्न प्रकार से अवलोकनीय सरणी तत्वों का उपयोग कर सकते हैं।
alert('The second element is ' + arrayName()[1]);
अवलोकनीय गुण
नॉकआउट जेएस के पास ऑब्जर्वेबल एरे फ़ंक्शन का अपना सेट है। वे सुविधाजनक हैं क्योंकि -
ये फ़ंक्शन सभी ब्राउज़रों पर काम करते हैं।
ये कार्य स्वचालित रूप से निर्भरता ट्रैकिंग का ध्यान रखेंगे।
सिंटेक्स का उपयोग करना आसान है। उदाहरण के लिए, किसी तत्व को किसी सरणी में सम्मिलित करने के लिए, आपको बस सरणी नाम () (पुश) ('मान') के बजाय arrayName.push ('value') का उपयोग करने की आवश्यकता है।
निम्नलिखित विभिन्न अवलोकन योग्य ऐरे विधियों की सूची है।
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | धक्का ( 'मान')
सरणी के अंत में एक नया आइटम सम्मिलित करता है। |
2 | पॉप()
सरणी से अंतिम आइटम निकालता है और उसे वापस करता है। |
3 | unshift ( 'मान')
सरणी की शुरुआत में एक नया मान सम्मिलित करता है। |
4 | खिसक जाना()
सरणी से पहला आइटम निकालता है और उसे वापस करता है। |
5 | उलटना()
सरणी के क्रम को उलट देता है। |
6 | प्रकार ()
आरोही क्रम में आइटमों को सॉर्ट करता है। |
7 | जोड़ (स्टार्ट-सूचकांक, अंत इंडेक्स)
2 मापदंडों को स्वीकार करता है - स्टार्ट-इंडेक्स और एंड-इंडेक्स - शुरू से अंत तक के आइटम हटाता है और उन्हें एक सरणी के रूप में वापस करता है। |
8 | indexOf ( 'मान')
यह फ़ंक्शन प्रदान किए गए पैरामीटर की पहली घटना का सूचकांक देता है। |
9 | टुकड़ा (स्टार्ट-सूचकांक, अंत इंडेक्स)
यह विधि किसी सरणी का एक टुकड़ा निकालती है। स्टार्ट-इंडेक्स से एंड-इंडेक्स तक आइटम लौटाता है। |
10 | सभी हटाएं()
सभी आइटम निकालता है और उन्हें एक सरणी के रूप में लौटाता है। |
1 1 | ( 'मान') को हटा दें
पैरामीटर से मेल खाने वाली वस्तुओं को निकालता है और एक सरणी के रूप में देता है। |
12 | निकालें (फ़ंक्शन (आइटम) {कंडीशन})
उन वस्तुओं को निकालता है जो स्थिति को संतोषजनक कर रहे हैं और उन्हें एक सरणी के रूप में लौटाते हैं। |
13 | निकालें ([मूल्यों का सेट)
उन आइटमों को निकालता है जो दिए गए मानों के साथ मेल खाते हैं। |
14 | destroyAll() सभी आइटमों को एक ऐसे अक्षर में चिह्नित करता है जिसके पास संपत्ति है। |
15 | destroy('value') पैरामीटर के बराबर एक आइटम के लिए खोज करता है और इसे एक विशेष संपत्ति के साथ चिह्नित करता है _destroy मान सच के साथ। |
16 | destroy(function(item) { condition}) उन सभी वस्तुओं को ढूंढता है जो स्थिति को संतोषजनक कर रहे हैं, उन्हें सही मूल्य के साथ संपत्ति _destroy के साथ चिह्नित करता है। |
17 | destroy([set of values]) उन आइटमों को ढूँढता है जो दिए गए मानों के साथ मेल खाते हैं, उन्हें सच्चे मान के साथ _destroy के रूप में चिह्नित करता है। |
Note - नष्ट और नष्ट। अवलोकन से सभी कार्य ज्यादातर 'रूबी ऑन रेल' डेवलपर्स के लिए ही होते हैं।
जब आप विध्वंस विधि का उपयोग करते हैं, तो संबंधित आइटम वास्तव में उस समय सरणी से हटाए नहीं जाते हैं, लेकिन उन्हें सही मूल्य के साथ संपत्ति _destroy के साथ चिह्नित करके छिपा दिया जाता है ताकि वे यूआई द्वारा नहीं पढ़ सकें। सत्य के बराबर _destroy के रूप में चिह्नित आइटम JSON ऑब्जेक्ट ग्राफ़ के साथ काम करते समय बाद में हटा दिए जाते हैं।