नॉकआउट जेएस - घोषणात्मक बाइंडिंग

नॉकआउट जेएस में घोषणात्मक बंधन यूआई से डेटा कनेक्ट करने का एक शक्तिशाली तरीका प्रदान करता है।

बाइंडिंग और ऑब्जर्वबल्स के बीच संबंध को समझना महत्वपूर्ण है। तकनीकी रूप से, ये दोनों अलग हैं। आप सामान्य जावास्क्रिप्ट ऑब्जेक्ट का उपयोग कर सकते हैं क्योंकि ViewModel और KnockoutJS व्यू के बाइंडिंग को सही ढंग से संसाधित कर सकते हैं।

अवलोकन के बिना, UI से संपत्ति केवल पहली बार संसाधित की जाएगी। इस स्थिति में, यह अंतर्निहित डेटा अपडेट के आधार पर स्वचालित रूप से अपडेट नहीं हो सकता है। इसे प्राप्त करने के लिए, बाइंडिंग को अवलोकन योग्य गुणों के लिए संदर्भित किया जाना चाहिए।

बाइंडिंग सिंटेक्स

बाइंडिंग में 2 आइटम होते हैं, बाइंडिंग name तथा value। निम्नलिखित एक सरल उदाहरण है -

Today is : <span data-bind = "text: whatDay"></span>

यहाँ, पाठ बाध्यकारी नाम है और whatDay बाध्यकारी मूल्य है। आपको अल्पविराम द्वारा अलग-अलग कई बाइंडिंग मिल सकती हैं, जैसा कि निम्नलिखित सिंटैक्स में दिखाया गया है।

Your name: <input data-bind = "value: yourName, valueUpdate: 'afterkeydown'" />

यहां, प्रत्येक कुंजी को दबाए जाने के बाद मूल्य अपडेट किया जाता है।

बंधन मान

बाध्यकारी मूल्य एक हो सकता है single value, literal, ए variable या हो सकता है JavaScriptअभिव्यक्ति। यदि बाध्यकारी कुछ अमान्य अभिव्यक्ति या संदर्भ को संदर्भित करता है, तो KO एक त्रुटि उत्पन्न करेगा और बाध्यकारी को संसाधित करना बंद कर देगा।

बाइंडिंग के कुछ उदाहरण निम्नलिखित हैं।

<!-- simple text binding -->
<p>Enter employee name: <input   -bind = 'value: empName' /></p>

<!-- click binding, call a specific function -->
<button data-bind="click: sortEmpArray">Sort Array</button>

<!-- options binding -->
<select multiple = "true" size = "8" data-bind = "options: empArray , 
   selectedOptions: chosenItem"> </select>

निम्नलिखित बिंदुओं पर ध्यान दें -

  • व्हॉट्सएप पर कोई फर्क नहीं पड़ता।

  • केओ 3.0 से शुरू होकर, आप बाध्यकारी मूल्य को छोड़ सकते हैं जो बाध्यकारी को अपरिभाषित मान देगा।

बाइंडिंग प्रसंग

वर्तमान बाइंडिंग में उपयोग किए जा रहे डेटा को किसी ऑब्जेक्ट द्वारा संदर्भित किया जा सकता है। इस वस्तु को कहा जाता हैbinding context

प्रसंग पदानुक्रम स्वचालित रूप से KnockoutJS द्वारा बनाया और प्रबंधित किया जाता है। निम्न तालिका KO द्वारा प्रदान किए गए विभिन्न प्रकार के बाध्यकारी संदर्भों को सूचीबद्ध करती है।

अनु क्रमांक। बाध्यकारी संदर्भ प्रकार और विवरण
1

$root

यह हमेशा शीर्ष स्तर ViewModel को संदर्भित करता है। यह ViewModel में हेरफेर करने के लिए शीर्ष स्तर के तरीकों का उपयोग करना संभव बनाता है। यह आमतौर पर ऑब्जेक्ट है, जो ko.applyBindings को पास किया जाता है।

2

$data

यह संपत्ति बहुत पसंद है thisजावास्क्रिप्ट ऑब्जेक्ट में कीवर्ड। एक बाध्यकारी संदर्भ में $ डेटा संपत्ति वर्तमान संदर्भ के लिए ViewModel ऑब्जेक्ट को संदर्भित करती है।

3

$index

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

4

$parent

यह गुण मूल ViewModel ऑब्जेक्ट को संदर्भित करता है। यह तब उपयोगी होता है जब आप नेस्टेड लूप के अंदर से बाहरी ViewModel गुणों को एक्सेस करना चाहते हैं।

5

$parentContext

संदर्भ वस्तु जो मूल स्तर पर बंधी होती है उसे कहा जाता है $parentContext। इससे अलग है$parent। $ जनक डेटा को संदर्भित करता है। जबकि, $ पेरेंटकोटेक्स्ट बाध्यकारी संदर्भ को संदर्भित करता है। उदाहरण के लिए, आपको आंतरिक संदर्भ से बाहरी फ़ॉर्च आइटम के सूचकांक तक पहुंचने की आवश्यकता हो सकती है।

6

$rawdata

यह संदर्भ वर्तमान स्थिति में कच्चे ViewModel मूल्य रखता है। यह $ डेटा जैसा दिखता है लेकिन अंतर यह है, अगर ViewModel ऑब्जर्वेबल में लिपटे हुए है, तो $ डेटा सिर्फ अलिखित हो जाता है। ViewModel और $ रॉडेटा वास्तविक अवलोकन डेटा बन जाता है।

7

$component

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

8

$componentTemplateNodes

जब आप किसी विशिष्ट घटक टेम्पलेट के भीतर हैं तो यह उस विशेष घटक को दिए गए DOM नोड्स की एक सरणी का प्रतिनिधित्व करता है।

निम्नलिखित शर्तें बंधन में भी उपलब्ध हैं लेकिन वास्तव में बाध्यकारी संदर्भ नहीं हैं।

  • $context - यह मौजूदा बाध्यकारी संदर्भ वस्तु के अलावा और कुछ नहीं है।

  • $element - यह ऑब्जेक्ट वर्तमान बाइंडिंग में DOM के एक तत्व को संदर्भित करता है।

टेक्स्ट और अपीयरेंस के साथ काम करना

निम्नलिखित पाठ और दृश्य दिखावे से निपटने के लिए KO द्वारा प्रदान किए गए बाध्यकारी प्रकारों की एक सूची है।

अनु क्रमांक। बाइंडिंग प्रकार और उपयोग
1 दृश्यमान: <बाध्यकारी-स्थिति>

कुछ शर्तों के आधार पर HTML DOM तत्व दिखाने या छिपाने के लिए।

2 पाठ: <बाध्यकारी-मूल्य>

HTML DOM तत्व की सामग्री सेट करने के लिए।

3 html: <बाइंडिंग-वैल्यू>

डोम तत्व के HTML मार्कअप सामग्री को सेट करने के लिए।

4 css: <बाइंडिंग-ऑब्जेक्ट>

एक तत्व के लिए सीएसएस कक्षाएं लागू करने के लिए।

5 शैली: <बाध्यकारी-वस्तु>

किसी तत्व की इनलाइन शैली विशेषता को परिभाषित करने के लिए।

6 attr: <बाइंडिंग-ऑब्जेक्ट>

एक तत्व को गतिशील रूप से विशेषताएँ जोड़ने के लिए।

कंट्रोल फ्लो बाइंडिंग के साथ काम करना

निम्नलिखित KO द्वारा प्रदान की गई कंट्रोल फ़्लो बाइंडिंग प्रकारों की एक सूची है।

अनु क्रमांक। बाइंडिंग प्रकार और उपयोग
1 foreach: <बाइंडिंग-एरे>

इस बाइंडिंग में, प्रत्येक ऐरे आइटम को HTML मार्कअप में एक लूप में संदर्भित किया जाता है।

2 अगर: <बंधन-शर्त>

यदि स्थिति सही है, तो दिए गए HTML मार्कअप पर कार्रवाई की जाएगी। और, इसे डोम से हटा दिया जाएगा।

3 ifnot: <बाइंडिंग-कंडीशन>

की उपेक्षा। यदि स्थिति सही है, तो दिए गए HTML मार्कअप पर कार्रवाई की जाएगी। और, इसे डोम से हटा दिया जाएगा।

4 साथ: <बंधन-वस्तु>

इस बंधन का उपयोग किसी वस्तु के बाल तत्वों को निर्दिष्ट वस्तु के संदर्भ में बांधने के लिए किया जाता है।

5 घटक: <घटक-नाम> या घटक: <घटक-वस्तु>

इस बंधन का उपयोग डोम तत्वों में एक घटक को सम्मिलित करने और मापदंडों को वैकल्पिक रूप से पारित करने के लिए किया जाता है।

फॉर्म फील्ड्स बाइंडिंग के साथ काम करना

निम्नलिखित KO द्वारा प्रदान किए गए फॉर्म फील्ड्स बाइंडिंग प्रकारों की सूची है।

अनु क्रमांक। बाइंडिंग प्रकार और उपयोग
1 क्लिक करें: <बाइंडिंग-फंक्शन>

इस बंधन का उपयोग एक क्लिक के आधार पर DOM तत्व से जुड़े जावास्क्रिप्ट फंक्शन को शुरू करने के लिए किया जाता है।

2 घटना:

यह बाध्यकारी निर्दिष्ट DOM घटनाओं को सुनने और उन पर आधारित हैंडलर फ़ंक्शन को कॉल करने के लिए उपयोग किया जाता है।

3 सबमिट करें: <बाइंडिंग-फंक्शन>

जब संबद्ध डोमेन तत्व सबमिट किया जाता है तो यह बंधन एक जावास्क्रिप्ट फ़ंक्शन को लागू करने के लिए उपयोग किया जाता है।

4 सक्षम करें: <बाध्यकारी-मूल्य>

इस बंधन का उपयोग एक निर्दिष्ट स्थिति के आधार पर कुछ DOM तत्वों को सक्षम करने के लिए किया जाता है।

5 अक्षम करें: <बाध्यकारी-मूल्य>

यह बाध्यकारी संबंधित DOM तत्व को निष्क्रिय कर देता है जब पैरामीटर सही का मूल्यांकन करता है।

6 मूल्य: <बाध्यकारी-मूल्य>

इस बाइंडिंग का उपयोग संबंधित DOM तत्व के मूल्य को ViewModel संपत्ति में जोड़ने के लिए किया जाता है।

7 textInput: <बाइंडिंग-वैल्यू>

इस बंधन का उपयोग टेक्स्ट बॉक्स या टेक्सारिया और ViewModel संपत्ति के बीच 2-वे बाइंडिंग बनाने के लिए किया जाता है।

8 hasFocus: <बाइंडिंग-वैल्यू>

इस बाइंडिंग का उपयोग ViewModel प्रॉपर्टी के माध्यम से HTML DOM तत्व के फोकस को मैन्युअल रूप से सेट करने के लिए किया जाता है।

9 जाँच: <बाध्यकारी-मूल्य>

इस बाइंडिंग का उपयोग चेक करने योग्य फॉर्म एलिमेंट और व्यूमॉडल प्रॉपर्टी के बीच लिंक बनाने के लिए किया जाता है।

10 विकल्प: <बाध्यकारी-सरणी>

इस बंधन का उपयोग चुनिंदा तत्व के लिए विकल्पों को परिभाषित करने के लिए किया जाता है।

1 1 चयनित विकल्प: <बाध्यकारी-सरणी>

इस बाइंडिंग का उपयोग उन तत्वों के साथ काम करने के लिए किया जाता है, जिन्हें वर्तमान में मल्टी लिस्ट में चुना गया है।

12 अनूठे नाम: <बाध्यकारी-मूल्य>

यह बाध्यकारी एक DOM तत्व के लिए एक अद्वितीय नाम उत्पन्न करने के लिए उपयोग किया जाता है।