MooTools - चयनकर्ताओं
HTML तत्वों का चयन करने के लिए चयनकर्ताओं का उपयोग किया जाता है। जब भी आप इंटरैक्टिव वेब पेज बनाना चाहते हैं, तो आपको उस वेब पेज से कुछ डेटा या एक्शन का चयन करना होगा। चयनकर्ता तत्वों से HTML अनुरोध के माध्यम से डेटा प्राप्त करने में हमारी मदद करते हैं।
मूल चयनकर्ता ($)
$MooTools में मूल चयनकर्ता है। इसका उपयोग करके, आप इसके आईडी द्वारा DOM तत्व का चयन कर सकते हैं। उदाहरण के लिए, मान लें कि आपके पास एक HTML तत्व (जैसे div) हैbody_id।
<div id = "body_id">
</div>
यदि आप इस div का चयन करना चाहते हैं, तो निम्नलिखित सिंटैक्स का उपयोग करें -
वाक्य - विन्यास
//selects the element with the ID 'body_id'
$('body_id');
प्राप्ति ()
getElement () एक विधि है जो मूल चयनकर्ता ($) का विस्तार करती है। यह आपको तत्व आईडी का उपयोग करके अपने चयन को परिष्कृत करने की अनुमति देता है। getElement () केवल एकल तत्व का चयन करता है और कई विकल्प होने पर सबसे पहले वापस आएगा। आप किसी तत्व की पहली घटना प्राप्त करने के लिए क्लास नाम का भी उपयोग कर सकते हैं। लेकिन इसमें तत्वों की सरणी नहीं मिलेगी।
एकाधिक चयनकर्ता ($ $)
$$ का उपयोग कई तत्वों को चुनने और उन कई तत्वों को एक सरणी में रखने के लिए किया जाता है। उस सरणी से हम सूची को अलग-अलग तरीकों से हेरफेर, पुनर्प्राप्त और पुन: व्यवस्थित कर सकते हैं। निम्नलिखित सिंटैक्स पर एक नज़र डालें। यह परिभाषित करता है कि वेब पेज पर HTML तत्वों के संग्रह से सभी div तत्वों का चयन कैसे करें।
वाक्य - विन्यास
<div>
<div>a div</div>
<span id = "id_name">a span</span>
</div>
यदि आप सभी div का चयन करना चाहते हैं, तो निम्नलिखित सिंटैक्स का उपयोग करें -
वाक्य - विन्यास
//all divs in the page
$$('div');
यदि आप एक ही आईडी नाम के साथ कई div का चयन करना चाहते हैं, तो निम्न सिंटैक्स का उपयोग करें -
वाक्य - विन्यास
//selects the element with the id 'id_name' and all divs
$$('#id_name', 'div');
getElements ()
getElements () विधि getElement () विधि के समान है। यह विधि सभी तत्वों को मापदंड के अनुसार लौटाती है। आप या तो उपयोग कर सकते हैंelement name (a, div, input) उन संग्रहों या एक विशेष तत्व का चयन करने के लिए class name एक ही वर्ग के तत्वों के संग्रह का चयन करने के लिए।
ऑपरेटरों के साथ परिणामों को शामिल करें और बाहर करें
MooTools आपके चयन को परिष्कृत करने के लिए उपयोग किए जाने वाले विभिन्न ऑपरेटरों का समर्थन करता है। आप इन सभी ऑपरेटरों को getElements () विधि में उपयोग कर सकते हैं। इनमें से प्रत्येक ऑपरेटर नाम से एक इनपुट तत्व का चयन करने के लिए इस्तेमाल किया जा सकता है।
निम्नलिखित तालिका पर एक नज़र डालें। यह विभिन्न ऑपरेटरों को परिभाषित करता है जो MooTools का समर्थन करते हैं।
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
= (बराबर) | इसके नाम से इनपुट एलिमेंट चुनें। | $ ('body_wrap')। getElements ('इनपुट [नाम = phone_number]'); |
^ = (के साथ शुरू होता है) | नाम के अपने शुरुआती अक्षरों की तुलना करके इनपुट तत्व का चयन करें। | $ ('body_wrap')। getElements ('इनपुट [नाम ^ = फोन]'); |
$ = (के साथ समाप्त होता है) | नाम के इसके अंत अक्षरों की तुलना करके इनपुट तत्व का चयन करें। | $ ('body_wrap')। getElements ('इनपुट [नाम $ = संख्या]'); |
! = (के बराबर नहीं है) | नाम से इनपुट तत्व को डी-सेलेक्ट करें। | $ ('body_wrap')। getElements ('इनपुट [नाम! = पता]'); |
* = (शामिल हैं) | इनपुट तत्व का चयन करें जिसमें विशेष अक्षर पैटर्न है। | $ ('body_wrap')। getElements ('इनपुट [नाम * = फोन]'); |
तत्व आदेश के आधार पर चयनकर्ता
MooTools चयनकर्ता तत्व चयन में एक विशेष आदेश का पालन करते हैं। चयनकर्ता मुख्य रूप से दो आदेशों का पालन करते हैं; एक सम है और दूसरा विषम है।
Note - यह चयनकर्ता 0 से शुरू होता है, इसलिए पहला तत्व सम है।
यहां तक कि आदेश भी
इस क्रम में, चयनकर्ता उन तत्वों का चयन करता है जिन्हें एक समान क्रम में रखा जाता है। अपने HTML पृष्ठ में सभी divs का चयन करने के लिए निम्न सिंटैक्स का उपयोग करें।
Syntax
// selects all even divs
$$('div:even');
अजीब आदेश
इस क्रम में, चयनकर्ता विषम क्रम में रखे गए तत्व का चयन करता है। अपने HTML पृष्ठ के सभी विषम विभाजनों का चयन करने के लिए निम्न सिंटैक्स का उपयोग करें।
Syntax
// selects all odd divs
$$('div:odd');
Example
निम्न उदाहरण दिखाता है कि एक चयनकर्ता कैसे काम करता है। मान लीजिए, एक वेबपेज पर एक टेक्स्टबॉक्स और प्रौद्योगिकियों की एक सूची है। यदि आप टेक्स्ट बॉक्स में उस नाम को दर्ज करके सूची में से एक तकनीक चुनते हैं, तो सूची आपके इनपुट के आधार पर फ़िल्टर किए गए परिणामों को दिखाती है। यह MooTools चयनकर्ता का उपयोग करना संभव है। चयनकर्ता का उपयोग करके, हम टेक्स्टबॉक्स में एक ईवेंट जोड़ सकते हैं। ईवेंट श्रोता टेक्स्टबॉक्स से डेटा उठाएगा और सूची से इसकी जांच करेगा। यदि यह सूची में है, तो सूची फ़िल्टर किए गए परिणामों को दिखाती है। निम्नलिखित कोड पर एक नज़र डालें।
<html>
<head>
<script type = "text/javascript" src = "MooTools-Core-1.6.0.js"></script>
<script type = "text/javascript" src = "MooTools-More-1.6.0.js"></script>
<script type = "text/javascript">
window.addEvent('domready',function(){
var input = $('filter');
// set the title attribute of every element
// to it's text in lowercase
$$('ul > li').each(function(item){
item.set('title', item.get('text').toLowerCase());
});
// the function we'll call when the user types
var filterList = function(){
var value = input.value.toLowerCase();
$$('li').setStyle('display','none');
// check the title attribute if it contains whatever the user is typing
$$('ul > li[title*=' + value + ']').setStyle('display','');
};
// make it happen
input.addEvent('keyup', filterList);
});
</script>
</head>
<body>
<p><input id = "filter" type = "text" /></p>
<ul>
<li>C</li>
<li>Cpp</li>
<li>Java</li>
<li>JavaScript</li>
<li>Hadoop</li>
<li>Hive</li>
<li>CouchDB</li>
</ul>
</body>
</html>
आपको निम्न आउटपुट प्राप्त होंगे -
Output