प्रोटोटाइप - त्वरित गाइड

प्रोटोटाइप क्या है?

प्रोटोटाइप एक जावास्क्रिप्ट फ्रेमवर्क है जिसका उद्देश्य गतिशील वेब अनुप्रयोगों के विकास को आसान बनाना है। प्रोटोटाइप को सैम स्टीफेंसन द्वारा विकसित किया गया था।

प्रोटोटाइप एक जावास्क्रिप्ट लाइब्रेरी है, जो आपको डोम को बहुत आसान और मजेदार तरीके से हेरफेर करने में सक्षम बनाता है जो सुरक्षित भी है (क्रॉस-ब्राउज़र)।

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

Prototype -

  • डोम तत्वों और उपयोगी तरीकों के साथ अंतर्निहित प्रकार का विस्तार करता है।

  • विरासत के साथ वर्ग-शैली OOP के लिए अंतर्निहित समर्थन है।

  • इवेंट मैनेजमेंट के लिए उन्नत समर्थन है।

  • शक्तिशाली अजाक्स विशेषताएं हैं।

  • एक पूर्ण अनुप्रयोग विकास ढांचा नहीं है।

  • विगेट्स या मानक एल्गोरिदम या I / O सिस्टम का एक पूरा सेट प्रदान नहीं करता है।

प्रोटोटाइप कैसे स्थापित करें?

प्रोटोटाइप को एक फ़ाइल के रूप में वितरित किया जाता है, जिसे प्रोटोटाइप .js कहा जाता है। प्रोटोटाइप लाइब्रेरी सेटअप करने के लिए नीचे दिए गए चरणों का पालन करें -

  • एक सुविधाजनक पैकेज में नवीनतम संस्करण को हथियाने के लिए डाउनलोड पृष्ठ (http://prototypjs.org/download/) पर जाएं।

  • अब, अपनी वेबसाइट की एक निर्देशिका, जैसे / जावास्क्रिप्ट में prototyp.js फ़ाइल डालें।

अब आप अपने वेब पृष्ठों में शक्तिशाली प्रोटोटाइप ढांचे का उपयोग करने के लिए तैयार हैं।

प्रोटोटाइप लाइब्रेरी का उपयोग कैसे करें?

अब, आप निम्नानुसार प्रोटोटाइप स्क्रिप्ट शामिल कर सकते हैं -

<html>
   <head>
      <title>Prototype examples</title> 
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
   </head>
   
   <body>
      ........
   </body>
</html>

उदाहरण

यहां एक सरल उदाहरण दिखाया गया है कि आप अपने जावास्क्रिप्ट में DOM तत्वों को प्राप्त करने के लिए प्रोटोटाइप के $ () फ़ंक्शन का उपयोग कैसे कर सकते हैं -

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         function test() {
            node = $("firstDiv");
            alert(node.innerHTML);
         }
      </script>
   </head>

   <body>
      <div id = "firstDiv">
         <p>This is first paragraph</p> 
      </div>
      
      <div id = "secondDiv">
         <p>This is another paragraph</p>
      </div>
      
      <input type = "button" value = "Test $()" onclick = "test();"/>
   </body>
</html>

उत्पादन

यह ट्यूटोरियल क्यों?

प्रोटोटाइप फ़्रेमवर्क के लिए एक बहुत अच्छा प्रलेखन prototypjs.org पर उपलब्ध है, फिर किसी को इस ट्यूटोरियल को क्यों देखना चाहिए!

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

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

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

क्रॉस ब्राउज़र समर्थन

जावास्क्रिप्ट प्रोग्रामिंग करते समय, अलग-अलग वेब ब्राउजर को अलग-अलग हैंडल करना आवश्यक है। प्रोटोटाइप लाइब्रेरी को इस तरह से लिखा गया है कि यह सभी संगतता मुद्दों की देखभाल करता है और आप बिना किसी परेशानी के ब्राउज़र प्रोग्रामिंग को पार कर सकते हैं।

द डॉक्यूमेंट ऑब्जेक्ट मॉडल

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

HTML प्रपत्र

अजाक्स के साथ, अन्य इनपुट तंत्र जैसे कि ड्रैग एंड ड्रॉप, ब्राउज़र और सर्वर के बीच बातचीत के हिस्से के रूप में उपयोग किया जा सकता है। पारंपरिक जावास्क्रिप्ट प्रोग्रामिंग के साथ, इन निविष्टियों को पकड़ना और उन्हें सर्वर पर पारित करना मुश्किल है। प्रोटोटाइप HTML रूपों के साथ काम करने के लिए उपयोगिताओं का एक सेट प्रदान करता है।

जावास्क्रिप्ट घटनाएँ

प्रोटोटाइप घटनाओं को कोड करते समय कुछ उत्कृष्ट क्रॉस-ब्राउज़र समर्थन प्रदान करता है, और फ़ंक्शन ऑब्जेक्ट को इवेंट हैंडलिंग के साथ काम करना आसान बनाने के लिए भी विस्तारित करता है।

अजाक्स उपयोगिताएँ

प्रोटोटाइप की सबसे महत्वपूर्ण विशेषता यह अजाक्स के लिए समर्थन है। सभी प्रमुख ब्राउज़र XMLHttpRequest ऑब्जेक्ट के एक संस्करण का समर्थन करते हैं जो Ajax को संभव बनाता है, या तो ActiveX घटक के रूप में या मूल जावास्क्रिप्ट ऑब्जेक्ट के रूप में।

हालाँकि, XMLHttpRequest, HTTP प्रोटोकॉल को बहुत निचले स्तर पर उजागर करता है, जो डेवलपर को बहुत अधिक शक्ति देता है, लेकिन सरल काम करने के लिए उसे बहुत सारे कोड लिखने की भी आवश्यकता होती है।

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

प्रोटोटाइप लाइब्रेरी बहुत सारी पूर्वनिर्धारित वस्तुओं और उपयोगिता कार्यों के साथ आती है। आप सीधे अपने जावास्क्रिप्ट प्रोग्रामिंग में उन कार्यों और वस्तुओं का उपयोग कर सकते हैं।

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

इस अध्याय में उदाहरण के साथ इन सभी उपयोगी विधियों का विवरण है।

क्र.सं. विधि और विवरण
1। $ ()

यदि स्ट्रिंग के साथ प्रदान किया गया है, तो मेल आईडी के साथ दस्तावेज़ में तत्व लौटाता है; अन्यथा पारित तत्व लौटाता है।

2। $$ ()

CSS चयनकर्ताओं (स्ट्रिंग्स) की एक मनमानी संख्या लेता है और विस्तारित DOM तत्वों में से कोई भी दस्तावेज़-ऑर्डर सरणी देता है जो उनमें से किसी से मेल खाता है।

3। $ A ()

एकल तर्क को एक Array ऑब्जेक्ट में प्राप्त करता है।

4। $ एफ ()

प्रपत्र नियंत्रण का मान लौटाता है। यह Form.Element.getValue का एक सुविधा उपनाम है।

5। $ एच ()

सहवर्ती सरणियों से मिलती-जुलती वस्तुओं को असंख्य हैश वस्तुओं में परिवर्तित करता है।

6। $ आर ()

एक नया ObjectRange ऑब्जेक्ट बनाता है।

7। w $ ()

एक स्ट्रिंग को ऐरे में विभाजित करता है, जो सभी व्हाट्सएप को सीमांकक मानता है।

8। इन्हें कोशिश करें

कार्यों की एक मनमानी संख्या को स्वीकार करता है और पहले वाले के परिणाम को लौटाता है जो एक त्रुटि नहीं फेंकता है।

document.getElementsByClassName

यह विधि उन सभी तत्वों को पुनः प्राप्त करती है (और विस्तारित करती है) जिनमें क्लासनेम का CSS वर्ग नाम होता है

हालाँकि, इस पद्धति को प्रोटोटाइप के नवीनतम संस्करणों में चित्रित किया गया है।

तत्व वस्तु डोम में तत्व जोड़ तोड़ के लिए विभिन्न उपयोगिता कार्यों प्रदान करता है।

यहां उदाहरणों के साथ सभी उपयोगिता कार्यों की सूची दी गई है। यहाँ परिभाषित सभी तरीके $ () फ़ंक्शन का उपयोग करके स्वचालित रूप से एक्सेस किए गए किसी भी तत्व में जोड़ दिए गए हैं।

तो, Element.show ('firstDiv') लिखना; $ ('firstDiv') लिखने के समान है। शो ();

प्रोटोटाइप तत्व विधि

NOTE - सुनिश्चित करें कि आपके पास प्रोटोटाइप .js का कम से कम संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। absolutize ()

पृष्ठ लेआउट में अपनी स्थिति को बदले बिना तत्व को एक पूर्ण रूप से तैनात तत्व में बदल देता है।

2। addClassName ()

दिए गए CSS वर्ग के नाम को तत्व के वर्ग नामों में जोड़ता है।

3। addMethods ()

तत्व ऑब्जेक्ट में अपने स्वयं के तरीकों में मिश्रण करना संभव बनाता है, जिसे आप बाद में विस्तारित तत्वों के तरीकों के रूप में उपयोग कर सकते हैं।

4। सटा हुआ()

वर्तमान तत्व के सभी भाई-बहनों को ढूंढता है जो दिए गए चयनकर्ता से मेल खाते हैं।

5। पूर्वजों ()

तत्व के सभी पूर्वजों को एकत्र करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में वापस करता है।

6। childElements ()

तत्व के सभी बच्चों को इकट्ठा करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में वापस करता है।

7।

classNames()

पदावनत। ClassNames का एक नया उदाहरण देता है, एक Enumerable ऑब्जेक्ट जो तत्व के CSS क्लास नामों को पढ़ता और लिखता था।

8। cleanWhitespace ()

तत्व के सभी पाठ नोड्स को हटाता है, जिसमें केवल व्हाट्सएप होता है। तत्व देता है।

9। clonePosition ()

वैकल्पिक तर्क विकल्पों द्वारा परिभाषित तत्व पर स्थिति और / या स्रोत के आयामों को क्लोन करता है।

10। cumulativeOffset ()

दस्तावेज़ के ऊपरी बाएँ कोने से तत्व के ऑफ़सेट लौटाता है।

1 1। cumulativeScrollOffset ()

नेस्टेड स्क्रॉलिंग कंटेनर में एक तत्व की संचयी स्क्रॉल ऑफसेट की गणना करता है।

12। descendantOf ()

जाँचता है कि क्या तत्व पूर्वज का वंशज है।

13। वंशज()

तत्व के सभी वंशों को एकत्र करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में लौटाता है।

14। नीचे ()

तत्व का पहला वंशज जो cssRule से मेल खाता है। यदि कोई cssRule प्रदान नहीं किया जाता है, तो सभी वंशज माने जाते हैं। यदि कोई भी वंशज इन मानदंडों से मेल नहीं खाता है, तो अपरिभाषित लौटा दिया जाता है।

15। खाली ()

टेस्ट कि क्या तत्व खाली है (यानी, केवल व्हॉट्सएप शामिल है)।

16। विस्तार ()

Element.Methods और Element.Methods.Simulated में निहित सभी तरीकों के साथ तत्व का विस्तार करता है।

17। आग()

अपने लक्ष्य के रूप में वर्तमान तत्व के साथ एक कस्टम घटना को फायर करता है।

18। firstDescendant ()

पहला बच्चा लौटाता है जो एक तत्व है। यह FirstChild DOM प्रॉपर्टी के विरोध में है, जो किसी भी नोड को लौटा देगा।

19। getDimensions ()

किसी तत्व की गणना की गई चौड़ाई और ऊँचाई को ढूँढता है और उन्हें किसी वस्तु की कुंजी / मान जोड़े के रूप में लौटाता है।

20।

getElementsByClassName

पदावनत। सभी तत्वों के वंश को प्राप्त करता है, जिसमें क्लासनेम का एक CSS वर्ग होता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में लौटाता है। कृपया $$ () का उपयोग करें।

21।

getElementsBySelector

पदावनत। CSS चयनकर्ताओं (स्ट्रिंग्स) की एक मनमानी संख्या लेता है और उनमें से किसी से मेल खाने वाले तत्व के विस्तारित बच्चों की एक सरणी देता है। कृपया $$ () का उपयोग करें।

22। getHeight ()

तत्व की गणना की गई ऊंचाई को ढूँढता है और लौटाता है।

23। getOffsetParent ()

एलिमेंट का निकटतम निकटतम पूर्वज देता है। यदि कोई नहीं मिला, तो शरीर तत्व वापस आ गया है।

24। getStyle ()

तत्व के दिए गए CSS गुण मान लौटाता है। संपत्ति को उसके सीएसएस या संगठित रूप में निर्दिष्ट किया जा सकता है।

25। getWidth ()

तत्व की गणना की गई चौड़ाई को ढूँढता है और लौटाता है।

26। hasClassName ()

जाँचता है कि क्या तत्व में दिए गए CSS क्लासनाम है।

27। छिपाना()

तत्व को छिपाता है और लौटाता है।

28। पहचान()

तत्व की आईडी विशेषता देता है यदि यह मौजूद है, या एक अद्वितीय, स्वतः जनरेट की गई आईडी को सेट या रिटर्न करता है।

29।

immediateDescendants()

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

30। डालने ()

सामग्री के पहले, बाद में, या तत्व के निचले भाग में सामग्री सम्मिलित करता है।

31। निरीक्षण()

तत्व के डीबग-उन्मुख स्ट्रिंग प्रतिनिधित्व लौटाता है।

32। makeClipping ()

तत्व के अतिप्रवाह मूल्य को 'छिपा' पर सेट करके खराब तरीके से समर्थित सीएसएस क्लिप संपत्ति का अनुकरण करता है। तत्व देता है।

33। makePositioned ()

तत्व की सीएसएस स्थिति को 'सापेक्ष' में सेट करके ब्लॉक वाले सीएसएस के आसान निर्माण के लिए अनुमति देता है यदि इसकी प्रारंभिक स्थिति या तो 'स्थिर' या अविकसित हो। तत्व देता है।

34। से मेल ()

अगर तत्व दिए गए CSS चयनकर्ता से मेल खाता है तो जाँच करता है।

35। आगे()

एलिमेंट का निम्नलिखित सिबलिंग है जो दिए गए cssRule से मेल खाता है।

36। nextSiblings ()

सभी तत्वों के अगले भाई-बहनों को इकट्ठा करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में लौटाता है।

37। निरीक्षण ()

तत्व और रिटर्न तत्व पर एक घटना हैंडलर पंजीकृत करता है।

38। positionedOffset ()

अपने निकटतम पूर्वज के सापेक्ष तत्व की भरपाई करता है।

39। पिछला ()

तत्व का पिछला सिबलिंग जो दिए गए cssRule से मेल खाता है।

40। previousSiblings ()

तत्व के पिछले भाई-बहनों को एकत्र करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में वापस करता है।

41। readAttribute ()

तत्व की विशेषता या शून्य का मान लौटाता है यदि विशेषता निर्दिष्ट नहीं की गई है।

42। recursivelyCollect ()

पुन: उन तत्वों को एकत्रित करता है जिनके संबंध संपत्ति द्वारा निर्दिष्ट होते हैं।

43। relativize ()

पृष्ठ लेआउट में अपनी स्थिति बदले बिना तत्व को अपेक्षाकृत स्थित तत्व में बदल देता है।

44। हटाना ()

पूरी तरह से दस्तावेज़ से तत्व निकालता है और इसे वापस करता है।

45। removeClassName ()

एलिमेंट का CSS क्लासनेम और रिटर्न एलिमेंट हटाता है।

46। बदलने के ()

HTML तर्क की सामग्री द्वारा तत्व को प्रतिस्थापित करता है और हटाए गए तत्व को वापस करता है।

47। स्क्रॉल करें ()

विंडो को स्क्रॉल करता है ताकि तत्व व्यूपोर्ट के शीर्ष पर दिखाई दे। तत्व देता है।

48। चुनते हैं()

CSS चयनकर्ताओं (स्ट्रिंग्स) की एक मनमानी संख्या लेता है और उनमें से किसी से मेल खाने वाले तत्व के विस्तारित वंशज की एक सरणी देता है।

49। setOpacity ()

विभिन्न ब्राउज़रों में विसंगतियों के आसपास काम करते समय एक तत्व की दृश्य अस्पष्टता निर्धारित करता है।

50। setStyle ()

तत्व के सीएसएस शैली गुणों को संशोधित करता है।

51। प्रदर्शन()

प्रदर्शन और रिटर्न तत्व।

52। एक माँ की संताने()

तत्व के सभी भाई-बहनों को एकत्र करता है और उन्हें विस्तारित तत्वों की एक सरणी के रूप में लौटाता है।

53। stopObserving ()

Unregisters हैंडलर और रिटर्न तत्व।

54। टॉगल ()

तत्व की दृश्यता को टॉगल करता है।

55। toggleClassName ()

तत्व का CSS className और रिटर्न तत्व।

56। undoClipping ()

तत्व की CSS अतिप्रवाह संपत्ति को उस मान पर वापस सेट करता है, जो Element.makeClipping () लागू होने से पहले था। तत्व देता है।

57। undoPositioned ()

तत्व को वापस उसी स्थिति में ले जाता है, जब वह Element.makePositioned से पहले लागू किया गया था। तत्व देता है।

58। यूपी()

तत्व का पहला पूर्वज जो दिए गए cssRule से मेल खाता है।

59। अपडेट करें()

प्रदान किए गए नए तर्क और रिटर्न तत्व के साथ तत्व की सामग्री को प्रतिस्थापित करता है।

60। viewportOffset ()

व्यूपोर्ट के सापेक्ष तत्व के X / Y निर्देशांक लौटाता है।

61। दृश्य ()

एक बूलियन इंगित करता है कि तत्व दिखाई दे रहा है या नहीं।

62। रैप ()

एक तत्व को दूसरे के अंदर लपेटता है, फिर रैपर को वापस करता है।

63। writeAttribute ()

एक हैश या एक नाम / मूल्य जोड़ी के रूप में पारित विशेषताओं को जोड़ता, निर्दिष्ट या हटाता है।

प्रदान करने के लिए प्रोटोटाइप मूल जावास्क्रिप्ट संख्या बढ़ाता है -

  • ObjectRange संगतता, संख्या # succ के माध्यम से।

  • रूबी की तरह संख्या # के साथ संख्यात्मक छोरों।

  • सिंपल यूटिलिटी मेथड्स जैसे नंबर # toColorPart और नंबर # toPaddedString।

यहां संख्याओं से निपटने वाले उदाहरणों के साथ सभी कार्यों की सूची दी गई है।

प्रोटोटाइप संख्या विधि

NOTE - सुनिश्चित करें कि आपके पास 1.6 का प्रोटोटाइप.जेएस संस्करण है।

क्र.सं. विधि और विवरण
1। पेट ()

संख्या का निरपेक्ष मान लौटाता है।

2। प्लस्तर लगाना ()

संख्या से अधिक या उसके बराबर सबसे छोटा पूर्णांक देता है।

3। मंज़िल()

संख्या से कम या उसके बराबर सबसे बड़ा पूर्णांक लौटाता है।

4। गोल()

संख्या को निकटतम पूर्णांक तक ले जाता है।

5। succ ()

वर्तमान संख्या के उत्तराधिकारी को लौटाता है, जैसा कि वर्तमान + 1 द्वारा परिभाषित किया गया है। इसका उपयोग ObjectRange के साथ संगत संख्याएँ बनाने के लिए किया जाता है।

6। बार ()

एक नियमित [0..n] लूप, रूबी-शैली को एनकैप्सुलेट करता है।

7। toColorPart ()

संख्या का 2-अंकीय हेक्साडेसिमल निरूपण करता है (जिसे [0..255] श्रेणी में माना जाता है)। सीएसएस रंग के तार की रचना के लिए उपयोगी।

8। toJSON ()

एक JSON स्ट्रिंग देता है।

9। toPaddedString ()

संख्या को 0 के साथ गद्देदार स्ट्रिंग में परिवर्तित करता है ताकि स्ट्रिंग की लंबाई कम से कम लंबाई के बराबर हो।

प्रोटोटाइप स्ट्रिंग ऑब्जेक्ट को उपयोगी तरीके से लेकर तुच्छ से जटिल तक बढ़ाता है।

यहां स्ट्रिंग के साथ काम करने वाले उदाहरणों के साथ सभी कार्यों की सूची है।

प्रोटोटाइप स्ट्रिंग के तरीके

NOTE - सुनिश्चित करें कि आपके पास 1.6 का प्रोटोटाइप.जेएस संस्करण है।

क्र.सं. विधि और विवरण
1। खाली ()

जाँचता है कि क्या स्ट्रिंग 'रिक्त' है, जिसका अर्थ है या तो रिक्त या केवल व्हाट्सएप युक्त।

2। camelize ()

एक तारकोल द्वारा अलग किए गए स्ट्रिंग को एक कैमेलकेस समकक्ष में परिवर्तित करता है। उदाहरण के लिए, 'फू-बार' को 'फूबर' में परिवर्तित किया जाएगा।

3। कैपिटल ()

एक स्ट्रिंग के पहले अक्षर को कैपिटल करता है और अन्य सभी को डाउन करता है।

4। dasherize ()

पानी के नीचे चरित्र ("_") के हर उदाहरण को एक डैश ("-") से बदल देता है।

5। खाली ()

जाँच करें कि क्या स्ट्रिंग खाली है।

6। इसी के साथ समाप्त होता है()

जाँचता है कि स्ट्रिंग स्ट्रिंग के साथ समाप्त होती है या नहीं।

7। escapeHTML ()

HTML विशेष वर्णों को उनकी इकाई समकक्षों में रूपांतरित करता है।

8। evalJSON ()

स्ट्रिंग में JSON का मूल्यांकन करता है और परिणामी वस्तु लौटाता है।

9। evalScripts ()

स्ट्रिंग में मौजूद किसी भी स्क्रिप्ट ब्लॉक की सामग्री का मूल्यांकन करता है। प्रत्येक स्क्रिप्ट द्वारा दिए गए मान से युक्त एक सरणी देता है।

10। extractScripts ()

स्ट्रिंग में मौजूद किसी भी स्क्रिप्ट ब्लॉक की सामग्री को निकालता है और उन्हें स्ट्रिंग की एक सरणी के रूप में लौटाता है।

1 1। gsub ()

किसी दिए गए पैटर्न की हर घटना के साथ स्ट्रिंग को लौटाता है, या तो एक नियमित स्ट्रिंग, फ़ंक्शन का लौटा हुआ मान या टेम्पलेट स्ट्रिंग।

12। शामिल()

जाँचता है कि क्या स्ट्रिंग में एक विकल्प है।

13। निरीक्षण()

स्ट्रिंग का एक डिबग-उन्मुख संस्करण लौटाता है।

14। लगाना ()

स्ट्रिंग को एक टेम्पलेट के रूप में मानता है और इसे ऑब्जेक्ट के गुणों से भर देता है।

15। isJSON ()

जाँचता है कि क्या स्ट्रिंग नियमित अभिव्यक्ति के उपयोग द्वारा JSON मान्य है। इस सुरक्षा पद्धति को आंतरिक रूप से कहा जाता है।

16। parseQuery ()

एक URI जैसी क्वेरी स्ट्रिंग को पार्स करता है और पैरामीटर / मान जोड़े से बना एक ऑब्जेक्ट देता है।

17। स्कैन ()

दिए गए पैटर्न की प्रत्येक घटना पर पुनरावृत्ति की अनुमति देता है।

18। इसके साथ आरंभ होता है()

जाँचता है कि स्ट्रिंग स्ट्रिंग से शुरू होती है या नहीं।

19। पट्टी ()

एक स्ट्रिंग से सभी प्रमुख और अनुगामी व्हाट्सएप स्ट्रिप्स।

20। stripScripts ()

HTML स्क्रिप्ट ब्लॉक की तरह दिखने वाली किसी भी चीज की स्ट्रिप्स।

21। stripTags ()

स्ट्रिप किसी भी HTML टैग की एक स्ट्रिंग।

22। विषय()

पैटर्न की पहली गणना के साथ एक स्ट्रिंग लौटाता है, या तो एक नियमित स्ट्रिंग, किसी फ़ंक्शन या टेम्पलेट स्ट्रिंग का लौटाया गया मान।

23। succ ()

आंतरिक रूप से ObjectRange द्वारा उपयोग किया जाता है। स्ट्रिंग के अंतिम वर्ण को यूनिकोड वर्णमाला में निम्न वर्ण में परिवर्तित करता है।

24। बार ()

स्ट्रिंग गणना समय को समेटता है।

25। toArray ()

स्ट्रिंग चरित्र-दर-वर्ण को विभाजित करता है और परिणाम के साथ एक सरणी देता है।

26। toJSON ()

एक JSON स्ट्रिंग देता है।

27। toQueryParams ()

एक URI जैसी क्वेरी स्ट्रिंग को पार्स करता है और पैरामीटर / मान जोड़े से बना एक ऑब्जेक्ट देता है।

28। truncate ()

दी गई लंबाई को एक तार काटता है और इसे एक प्रत्यय जोड़ता है (यह दर्शाता है कि यह केवल एक अंश है)।

29। अंडरस्कोर ()

अंडरस्कोर ("_") द्वारा अलग किए गए शब्दों की एक श्रृंखला में एक संगठित स्ट्रिंग को परिवर्तित करता है।

30। unescapeHTML ()

स्ट्रिप्स टैग और विशेष HTML वर्णों के इकाई रूपों को उनके सामान्य रूप में परिवर्तित करता है।

31। अनफ़िल्टरजॉन ()

स्ट्रिप्स टिप्पणी अजाक्स JSON या जावास्क्रिप्ट प्रतिक्रियाओं के आसपास delimiters। इस सुरक्षा पद्धति को आंतरिक रूप से कहा जाता है।

प्रोटोटाइप सभी देशी जावास्क्रिप्ट सरणियों को कुछ शक्तिशाली तरीकों से बढ़ाता है।

यह दो तरीकों से किया जाता है -

  • यह Enumerable मॉड्यूल में मिश्रित होता है, जो पहले से ही तरीकों में से एक टन लाता है।

  • यह काफी कुछ अतिरिक्त तरीकों को जोड़ता है, जो इस खंड में प्रलेखित हैं।

Iterators का उपयोग करना

प्रोटोटाइप द्वारा प्रदान किया गया एक महत्वपूर्ण समर्थन यह है कि आप जावास्क्रिप्ट में जावास्क्रिप्ट की तरह जावा का उपयोग कर सकते हैं। नीचे अंतर देखें -

लिखने का पारंपरिक तरीका ए for पाश -

for (var index = 0; index < myArray.length; ++index) {
   var item = myArray[index];
   // Your code working on item here...
}

अब यदि आप प्रोटोटाइप का उपयोग कर रहे हैं, तो आप उपरोक्त कोड को निम्नानुसार बदल सकते हैं -

myArray.each(function(item) {
   // Your code working on item here...
});

एरे के साथ काम करने वाले उदाहरणों के साथ यहां सभी कार्यों की सूची दी गई है।

प्रोटोटाइप सरणी तरीके

NOTE - सुनिश्चित करें कि आपके पास 1.6 का प्रोटोटाइप.जेएस संस्करण है।

क्र.सं. विधि और विवरण
1। स्पष्ट()

सरणी को साफ़ करता है (इसे खाली करता है)।

2। क्लोन ()

सरणी की एक डुप्लिकेट लौटाता है, जिससे मूल सरणी बरकरार रहती है।

3। कॉम्पैक्ट ()

किसी भी अशक्त / अपरिभाषित मूल्यों के बिना, सरणी का एक नया संस्करण लौटाता है।

4। से प्रत्येक()

आरोही संख्यात्मक सूचकांक क्रम में सरणी पर Iterates।

5। प्रथम()

सरणी में पहला आइटम लौटाता है, या सरणी खाली होने पर अपरिभाषित होता है।

6। समतल ()

सरणी का एक "फ्लैट" (एक आयामी) संस्करण देता है।

7। (से)

एक मौजूदा सरणी क्लोन या एक सरणी की तरह संग्रह से एक नया बनाता है।

8। के सूचकांक()

सरणी के भीतर तर्क की पहली घटना की स्थिति देता है।

9। निरीक्षण()

किसी सरणी का डीबग-ओरिएंटेड स्ट्रिंग प्रतिनिधित्व लौटाता है।

10। पिछले ()

सरणी में अंतिम आइटम देता है, या सरणी खाली होने पर अपरिभाषित होता है।

1 1। कम करना()

सरणियों को कम करता है: एक-तत्व सरणियों को उनके अद्वितीय तत्व में बदल दिया जाता है, जबकि कई-तत्व सरणियों को अछूता लौटाया जाता है।

12। उलटना()

सरणी का उलटा संस्करण लौटाता है। डिफ़ॉल्ट रूप से, सीधे मूल को उलट देता है। यदि इनलाइन झूठी पर सेट है, तो मूल सरणी का क्लोन उपयोग करता है।

13। आकार ()

सरणी का आकार लौटाता है।

14। toArray ()

यह एन्यूमरेबल से मिश्रित-inArray का सिर्फ एक स्थानीय अनुकूलन है।

15। toJSON ()

एक JSON स्ट्रिंग देता है।

16। uniq ()

किसी सरणी के डुप्लिकेट-मुक्त संस्करण का निर्माण करता है। यदि कोई डुप्लिकेट नहीं मिलता है, तो मूल सरणी वापस आ जाती है।

17। के बिना()

उस सरणी का एक नया संस्करण तैयार करता है जिसमें कोई निर्दिष्ट मान नहीं होता है।

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

हैश बनाना

हैश उदाहरण के निर्माण के दो तरीके हैं -

  • जावास्क्रिप्ट कीवर्ड नया प्रयोग करें ।
  • प्रोटोटाइप उपयोगिता फ़ंक्शन $ H का उपयोग करना ।

एक खाली हैश बनाने के लिए आप बिना तर्क के किसी भी विधायक तरीके को कॉल करें।

निम्न उदाहरण दिखा रहा है कि कैसे हैश बनाया जाए, मूल्यों को स्थापित किया जाए और सरल तरीके से मूल्यों को प्राप्त किया जाए -

// Creating Hash
var myhash = new Hash();
var yourhash = new Hash( {fruit: 'apple'} );
var hishash = $H( {drink: 'pepsi'} );

// Set values in terms of key and values.
myhash.set('name', 'Bob');

// Get value of key 'name' as follows.
myhash.get('name');
yourhash.get('fruit');
hishash.get('drink');

// Unset a key & value
myhash.unset('name');
yourhash.unset('fruit');
hishash.unset('drink');

प्रोटोटाइप आसानी के साथ हाश का मूल्यांकन करने के लिए तरीकों की एक विस्तृत श्रृंखला प्रदान करता है। यह ट्यूटोरियल उपयुक्त उदाहरण के साथ हर विधि के बारे में विस्तार से बताएगा।

यहाँ हाश से संबंधित सभी विधियों की पूरी सूची दी गई है।

प्रोटोटाइप हैश मैथड्स

NOTE - सुनिश्चित करें कि कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। क्लोन ()

हैश का एक क्लोन लौटाता है।

2। से प्रत्येक()

हैश में नाम / मान जोड़े पर Iterates।

3। प्राप्त()

हैश कुंजी की संपत्ति का मान लौटाता है।

4। निरीक्षण()

हैश के डिबग-उन्मुख स्ट्रिंग प्रतिनिधित्व लौटाता है।

5। चांबियाँ()

हैश के लिए कुंजियों का एक सरणी प्रदान करता है (अर्थात, संपत्ति के नाम)।

6। मर्ज ()

उस हैश के परिणाम को मर्ज करता है और उस मर्ज का परिणाम देता है।

7। हटाना()

एक हैश से चाबियाँ निकालता है और उनके मूल्यों को वापस करता है। इस विधि को संस्करण 1.6 में पदावनत किया गया है।

8। सेट()

मूल्य और रिटर्न मान के लिए हैश कुंजी की संपत्ति सेट करता है।

9। toJSON ()

एक JSON स्ट्रिंग देता है।

10। वस्तु के लिए()

एक क्लोन, वेनिला वस्तु लौटाता है।

1 1। toQueryString ()

अपने URL-एन्कोडेड क्वेरी स्ट्रिंग प्रतिनिधित्व में एक हैश चालू करता है।

12। सेट नहीं ()

हैश कुंजी की संपत्ति को हटाता है और उसका मूल्य लौटाता है।

13। अपडेट करें()

वस्तु के प्रमुख / मूल्य जोड़े के साथ अद्यतन हैश। मूल हैश को संशोधित किया जाएगा।

14। मूल्यों ()

एक हैश के मूल्यों को एकत्र करता है और उन्हें एक सरणी में लौटाता है।

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

  • यदि आप एक साधारण डेवलपर हैं, तो आप मौजूदा कार्यों जैसे निरीक्षण या क्लोन का उपयोग कर सकते हैं ।

  • यदि आप एक ऐसे व्यक्ति हैं जो अपनी स्वयं की वस्तुओं को बनाना चाहते हैं जैसे कि प्रोटोटाइप करता है, या वस्तुओं का पता लगाता है जैसे कि वे हैश थे, तो विस्तार , कुंजियों और मूल्यों को बदल देंगे ।

प्रोटोटाइप ऑब्जेक्ट तरीके

NOTE - सुनिश्चित करें कि कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। क्लोन ()

उथली प्रतिलिपि का उपयोग करके पारित वस्तु को क्लोन करता है (परिणाम के सभी मूल गुणों की प्रतिलिपि बनाता है)।

2। विस्तार ()

स्रोत से गंतव्य ऑब्जेक्ट तक सभी गुणों की प्रतिलिपि बनाता है।

3। निरीक्षण()

ऑब्जेक्ट का डीबग-ओरिएंटेड स्ट्रिंग प्रतिनिधित्व लौटाता है।

4। ऐरे () है

सही है अगर obj एक सरणी है, तो गलत है।

5। isElement ()

सही है अगर obj टाइप 1 का DOM नोड है, तो गलत है।

6। isFunction ()

सही है अगर obj प्रकार के कार्य का है, तो गलत है।

7। isHash ()

सही है अगर obj हैश वर्ग का एक उदाहरण है, झूठे अन्यथा।

8। ISNUMBER ()

सही है अगर obj टाइप संख्या का है, तो गलत है।

9। isString ()

सही है अगर obj टाइप स्ट्रिंग का है, तो गलत है।

10। isUndefined ()

सही है अगर obj अपरिभाषित प्रकार का है, तो झूठे अन्यथा।

1 1। चांबियाँ()

किसी भी वस्तु को हैश मानता है और अपनी संपत्ति के नामों की सूची प्राप्त करता है।

12। toHTML ()

यदि मौजूद है, तो obj की HTML विधि का रिटर्न मान लौटाता है, अन्यथा String.interpret के माध्यम से obj चलाता है।

13। toJSON ()

एक JSON स्ट्रिंग देता है।

14। toQueryString ()

किसी वस्तु को उसके URL-एन्कोडेड क्वेरी स्ट्रिंग प्रतिनिधित्व में बदल देता है।

15। मूल्यों ()

किसी भी वस्तु को हैश मानता है और उसके संपत्ति मूल्यों की सूची प्राप्त करता है।

टेम्पलेट का उपयोग समान वस्तुओं के समूह को प्रारूपित करने और इन वस्तुओं के लिए स्वरूपित आउटपुट के लिए किया जाता है।

प्रोटोटाइप एक खाका वर्ग प्रदान करता है , जिसके दो तरीके हैं -

  • Template()- यह एक कंस्ट्रक्टर विधि है, जिसका उपयोग टेम्प्लेट ऑब्जेक्ट बनाने के लिए और टेम्प्लेट लगाने के लिए कॉल असेसमेंट () विधि के लिए किया जाता है।

  • evaluate() - इस विधि का उपयोग किसी वस्तु को प्रारूपित करने के लिए टेम्पलेट लगाने के लिए किया जाता है।

स्वरूपित आउटपुट बनाने के लिए तीन चरण शामिल हैं।

  • Create a template- इसमें पूर्वनिर्मित टेक्स्ट बनाना शामिल है। इस पाठ में स्वरूपित सामग्री के साथ है#{fieldName}मान। इन#{fieldName}मूल्यों को वास्तविक मूल्यों से बदल दिया जाएगा जब मूल्यांकन () विधि को वास्तविक मूल्यों के साथ कहा जाएगा।

  • Defining actual values- इसमें कुंजी और मान के रूप में वास्तविक मूल्य बनाना शामिल है। इन कीज़ को टेम्प्लेट में मैप किया जाएगा और उन्हें संबंधित मानों से बदल दिया जाएगा।

  • Mapping Keys and replacing Values- यह अंतिम चरण है जहां मूल्यांकन () कहा जाएगा और प्रारूपित वस्तु में उपलब्ध सभी कुंजियों को परिभाषित मूल्यों से बदल दिया जाएगा।

उदाहरण 1

चरण 1

एक टेम्पलेट बनाएँ।

var myTemplate = new Template('The \ TV show #{title} was directed by #{author}.');

चरण 2

मानों के हमारे सेट को तैयार करें, जो कि उपर्युक्त ऑब्जेक्ट में एक स्वरूपित आउटपुट के लिए पारित किया जाएगा।

var record1 = {title: 'Metrix', author:'Arun Pandey'};
var record2 = {title: 'Junoon', author:'Manusha'};
var record3 = {title: 'Red Moon', author:'Paul, John'};
var record4 = {title: 'Henai', author:'Robert'};
var records = [record1, record2, record3, record4 ];

चरण 3

अंतिम चरण टेम्पलेट में सभी मूल्यों को भर रहा है और अंतिम परिणाम का उत्पादन निम्नानुसार है -

records.each( function(conv) {
   alert( "Formatted Output : " + myTemplate.evaluate(conv) );
});

तो, आइए इन तीनों चरणों को एक साथ रखें -

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         function showResult() {
            //  Create template with formatted content and placeholders.
            var myTemplate = new Template('The \ TV show #{title} was directed by #{author}.');
   
            // Create hashes with the required values for placeholders
            var record1 = {title: 'Metrix', author:'Arun Pandey'};
            var record2 = {title: 'Junoon', author:'Manusha'};
            var record3 = {title: 'Red Moon', author:'Paul, John'};
            var record4 = {title: 'Henai', author:'Robert'};
            var records = [record1, record2, record3, record4 ];

            // Now apply template to produce desired formatted output
            records.each( function(conv) {
               alert( "Formatted Output : " + myTemplate.evaluate(conv) );
            });
         }
      </script>
   </head>

   <body>
      <p>Click the button to see the result.</p>
      <br />
      <br />
      <input type = "button" value = "Result" onclick = "showResult();"/>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

उत्पादन

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

एन्यूमरेशन मेथड का इस्तेमाल ज्यादातर एरेस और हैश की गणना करने के लिए किया जाता है । अन्य ऑब्जेक्ट्स के साथ-साथ ObjectRange और विभिन्न DOM- या AJAX- संबंधित ऑब्जेक्ट हैं जहां आप एन्यूमरेशन विधियों का उपयोग कर सकते हैं।

प्रसंग पैरामीटर

Enumerable की प्रत्येक विधि जो एक पुनरावृत्ति लेती है वह संदर्भ ऑब्जेक्ट को अगले (वैकल्पिक) पैरामीटर के रूप में भी लेती है। संदर्भ वस्तु वह है जो पुनरावृत्त को बाँधने वाला है, इसलिएthis इसके अंदर कीवर्ड ऑब्जेक्ट को इंगित करेगा।

var myObject = {};

['foo', 'bar', 'baz'].each(function(name, index) {
   this[name] = index;
}, myObject); // we have specified the context

myObject;

यह निम्नलिखित परिणाम का उत्पादन करेगा -

उत्पादन

{ foo: 0, bar: 1, baz: 2}

इसका कुशल उपयोग करना

  • जब आपको सभी तत्वों पर समान विधि लागू करने की आवश्यकता होती है, तो आह्वान () विधि के साथ जाएं।

  • जब आपको सभी तत्वों पर समान संपत्ति लाने की आवश्यकता होती है, तो प्लक () विधि के साथ जाएं।

  • FindAll / चयन के तरीकों सभी तत्वों कि किसी दिए गए विधेय से मेल पुनः प्राप्त। इसके विपरीत, अस्वीकार () विधि उन सभी तत्वों को पुनः प्राप्त करती है जो एक विधेय से मेल नहीं खाते हैं। विशिष्ट मामले में जहां आपको दोनों सेटों की आवश्यकता होती है, आप दो बार लूपिंग से बच सकते हैं: बस विभाजन () विधि का उपयोग करें ।

यहां Enumerable से संबंधित सभी विधियों की पूरी सूची दी गई है।

प्रोटोटाइप Enumerable तरीके

NOTE - सुनिश्चित करें कि आपके पास कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। सब()

यह निर्धारित करता है कि सभी तत्व बूलियन-समतुल्य हैं या नहीं, सीधे या पुनरावृत्ति के माध्यम से प्रदान किए गए पुनरावृत्ति द्वारा।

2। कोई भी()

निर्धारित करता है कि कम से कम एक तत्व बूलियन-सच के बराबर है, या तो सीधे या गणना के माध्यम से प्रदान की गई पुनरावृत्ति द्वारा।

3। इकट्ठा ()

प्रत्येक तत्व में पुनरावृत्ति को लागू करने के परिणाम लौटाता है। नक्शे के रूप में चिह्नित ()।

4। का पता लगाने ()

पहला तत्व ढूँढता है जिसके लिए पुनरावृत्ति सही है। खोज () विधि द्वारा अलियास किया गया।

5। से प्रत्येक()

यह आपको एक सामान्य शैली में सभी तत्वों पर पुनरावृति करने देता है, फिर Enumerable को लौटाता है, जिससे चेन-कॉलिंग की अनुमति मिलती है।

6। eachSlice ()

समूह किसी दिए गए आकार के आधार पर विखंडू में आइटम, अंतिम हिस्सा संभवतः छोटा होने के साथ।

7। प्रविष्टियों ()

अधिक सामान्य toArray विधि के लिए उपनाम।

8। लगता है ()

पहला तत्व ढूँढता है जिसके लिए पुनरावृत्ति सही है। पता लगाने के लिए सुविधा उपनाम ()।

9। सब ढूँढ़ो()

उन सभी तत्वों को लौटाता है जिनके लिए पुनरावृत्ति सही है। चयन के रूप में उपनामित ()।

10। ग्रेप ()

फ़िल्टर से मेल खाने वाले सभी तत्वों को लौटाता है। यदि एक पुनरावृत्त प्रदान किया जाता है, तो इसका उपयोग प्रत्येक चयनित तत्व के लिए दिए गए मान का उत्पादन करने के लिए किया जाता है।

1 1। inGroupsOf ()

यदि आवश्यक हो तो अंतिम चंक को भरने के लिए एक विशिष्ट मूल्य का उपयोग करके निश्चित आकार के चंक्स में समूह आइटम।

12। शामिल()

यह निर्धारित करता है कि किसी दिए गए ऑब्जेक्ट Enumerable में है या नहीं, == तुलना ऑपरेटर के आधार पर। सदस्य के रूप में उपनाम ()।

13। सुई ()

आकस्मिक रूप से पुनरावृत्त के परिणाम के आधार पर परिणाम मान बनाता है।

14। आह्वान ()

प्रत्येक () या एकत्र () के एक आम उपयोग के मामले के लिए अनुकूलन: सभी तत्वों के लिए एक ही संभावित तर्कों के साथ एक ही विधि को लागू करना।

15। नक्शा()

प्रत्येक तत्व में पुनरावृत्ति को लागू करने के परिणाम लौटाता है। संग्रह के लिए सुविधा उपनाम ()।

16। अधिकतम ()

अधिकतम तत्व (या तत्व-आधारित संगणना) लौटाता है, या यदि गणना खाली है तो अपरिभाषित है। तत्वों की या तो सीधे तुलना की जाती है, या पहले इट्रेटर लगाने और लौटे मूल्यों की तुलना की जाती है।

17। सदस्य()

यह निर्धारित करता है कि किसी दिए गए ऑब्जेक्ट Enumerable में है या नहीं, == तुलना ऑपरेटर के आधार पर। शामिल करने के लिए सुविधा उपनाम ()।

18। मिनट ()

न्यूनतम तत्व (या तत्व-आधारित संगणना), या अपरिभाषित अगर खाली है तो वापस लौटाता है। तत्वों की या तो सीधे तुलना की जाती है, या पहले इट्रेटर लगाने और लौटे मूल्यों की तुलना की जाती है।

19। विभाजन ()

तत्वों को दो समूहों में विभाजित करता है: जिन्हें सच माना जाता है, और जो झूठे माने जाते हैं।

20। प्लक ()

संग्रह के एक सामान्य उपयोग के मामले के लिए अनुकूलन (): सभी तत्वों के लिए समान संपत्ति लाना। गुण मान लौटाता है।

21। अस्वीकार()

उन सभी तत्वों को लौटाता है जिनके लिए पुनरावृत्ति करने वाला झूठे लौटता है।

22। चुनते हैं()

खोज के लिए उपनाम () विधि।

23। आकार ()

गणना का आकार देता है।

24। इसके अनुसार क्रमबद्ध करें()

प्रत्येक तत्व के लिए, पुनरावर्तक द्वारा गणना किए गए मानदंड के आधार पर तत्वों का एक कस्टम-सॉर्ट किया गया दृश्य प्रदान करता है।

25। toArray ()

एन्यूमरेशन का एरियर प्रतिनिधित्व लौटाता है। प्रविष्टियों के रूप में चिह्नित ()।

26। ज़िप ()

एक साथ ज़िप (पतलून की एक जोड़ी पर ज़िप के बारे में सोचो) 2 + अनुक्रम, टुपल्स की एक सरणी प्रदान करते हैं। प्रत्येक टपल में मूल अनुक्रम प्रति एक मान होता है।

इवेंट प्रबंधन क्रॉस-ब्राउज़र स्क्रिप्टिंग को प्राप्त करने के लिए सबसे बड़ी चुनौतियों में से एक है। हर ब्राउज़र में कुंजी स्ट्रोक को संभालने के लिए अलग-अलग दृष्टिकोण होते हैं।

प्रोटोटाइप फ्रेमवर्क सभी क्रॉस ब्राउज़र संगतता मुद्दों को संभालता है और आपको इवेंट मैनेजमेंट से संबंधित सभी परेशानी से मुक्त रखता है।

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

ईवेंट नेमस्पेस कुंजी कोड की एक मानकीकृत सूची भी प्रदान करता है जिसका उपयोग आप कीबोर्ड से संबंधित घटनाओं के साथ कर सकते हैं। निम्नलिखित स्थिरांक नामस्थान में परिभाषित किए गए हैं -

क्र.सं. प्रमुख निरंतर और विवरण
1।

KEY_BACKSPACE

वापस अंतरिक्ष कुंजी का प्रतिनिधित्व करते हैं।

2।

KEY_TAB

टैब कुंजी का प्रतिनिधित्व करें।

3।

KEY_RETURN

प्रतिनिधि वापस कुंजी।

4।

KEY_ESC

प्रतिनिधि एस्क कुंजी।

5।

KEY_LEFT

प्रतिनिधि ने चाबी छोड़ दी।

6।

KEY_UP

कुंजी का प्रतिनिधित्व करें।

7।

KEY_RIGHT

सही कुंजी का प्रतिनिधित्व करें।

8।

KEY_DOWN

कुंजी का प्रतिनिधित्व करें।

9।

KEY_DELETE

प्रतिनिधि कुंजी हटा दें।

10।

KEY_HOME

घर की चाबी का प्रतिनिधित्व करें।

1 1।

KEY_END

प्रतिनिधि अंत कुंजी।

12।

KEY_PAGEUP

प्रतिनिधि पृष्ठ कुंजी।

13।

KEY_PAGEDOWN

पृष्ठ नीचे कुंजी।

ईवेंट को कैसे हैंडल करें

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

उदाहरण

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         // Register event 'click' and associated call back.
         Event.observe(document, 'click', respondToClick);
  
         // Callback function to handle the event.
         function respondToClick(event) {
            var element = event.element();
            alert("Tag Name : " + element.tagName );
         }
      </script>
   </head>

   <body>
      <p id = "note"> Click on any part to see the result.</p>
      <p id = "para">This is paragraph</p>
      <div id = "division">This is divsion.</div>
   </body>
</html>

उत्पादन

यहाँ से संबंधित सभी विधियों की पूरी सूची दी गई है Event। जिन कार्यों का आप सबसे अधिक उपयोग करने की संभावना रखते हैं , वे अवलोकन , तत्व और स्टॉप हैं

प्रोटोटाइप घटना के तरीके

NOTE - सुनिश्चित करें कि आपके पास कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। तत्व ()

DOM तत्व लौटाता है जिस पर ईवेंट हुआ।

2। विस्तार ()

Event.Methods में निहित सभी विधियों के साथ ईवेंट का विस्तार करता है ।

3। findElement ()

किसी दिए गए टैग नाम के साथ पहला DOM तत्व लौटाता है, जिस पर वह घटना घटी है।

4। isLeftClick ()

निर्धारित करता है कि बटन से संबंधित माउस घटना "बाएं" (प्राथमिक, वास्तव में) बटन के बारे में थी।

5। निरीक्षण ()

DOM तत्व पर एक ईवेंट हैंडलर रजिस्टर करता है।

6। pointerX ()

एक माउस घटना के लिए पूर्ण क्षैतिज स्थिति देता है।

7। pointerY ()

एक माउस घटना के लिए पूर्ण ऊर्ध्वाधर स्थिति देता है।

8। रुकें()

ईवेंट के प्रचार को रोक देता है और अंततः इसकी डिफ़ॉल्ट कार्रवाई को ट्रिगर होने से रोकता है।

9। stopObserving ()

इवेंट हैंडलर को अनरजिस्टर्ड करता है।

10। unloadCache ()

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

प्रोटोटाइप HTML रूपों को प्रबंधित करने का एक आसान तरीका प्रदान करता है। प्रोटोटाइप का फॉर्म एक नामस्थान और सभी चीजों के लिए एक मॉड्यूल है जो फॉर्म-संबंधित है, फॉर्म हेरफेर और क्रमबद्धता अच्छाई के साथ पैक किया गया है।

जबकि यह एक पूरे के रूप में रूपों के साथ काम करने के तरीकों को रखता है, इसका उप मॉड्यूल फॉर्म है। क्लेमेंट विशिष्ट फॉर्म नियंत्रणों से संबंधित है।

यहाँ से संबंधित सभी विधियों की पूरी सूची दी गई है Form Element

प्रोटोटाइप फॉर्म के तरीके

NOTE - सुनिश्चित करें कि आपके पास कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। अक्षम ()

फ़ॉर्म को संपूर्ण के रूप में अक्षम करता है। प्रपत्र नियंत्रण दिखाई देंगे, लेकिन अप्राप्य।

2। (सक्षम करें)

एक पूर्ण या आंशिक रूप से अक्षम रूप में सक्षम करता है।

3। findFirstElement ()

पहले गैर-छिपे हुए, गैर-अक्षम फ़ॉर्म नियंत्रण को ढूँढता है।

4। focusFirstElement ()

प्रपत्र के पहले तत्व पर ध्यान केंद्रित करता है।

5। getElements ()

किसी प्रपत्र के भीतर सभी प्रपत्र नियंत्रणों का संग्रह लौटाता है।

6। getInputs ()

एक फॉर्म में सभी INPUT तत्वों का संग्रह लौटाता है। इन विशेषताओं पर खोज को प्रतिबंधित करने के लिए वैकल्पिक प्रकार और नाम के तर्कों का उपयोग करें।

7। निवेदन()

प्रपत्र की क्रिया विशेषता के URL में Ajax.Request के माध्यम से प्रपत्र को क्रमांकित और सबमिट करने के लिए एक सुविधा विधि। विकल्प पैरामीटर Ajax.Request उदाहरण के लिए पारित किया गया है, HTTP विधि को ओवरराइड करने और अतिरिक्त मापदंडों को निर्दिष्ट करने की अनुमति देता है।

8। रीसेट()

एक फॉर्म को उसके डिफ़ॉल्ट मानों पर रीसेट करता है।

9। क्रमबद्ध करें()

अजाक्स अनुरोधों (डिफ़ॉल्ट व्यवहार) के लिए उपयुक्त स्ट्रिंग के लिए प्रपत्र डेटा को सीरियलाइज़ करें या, यदि वैकल्पिक getHash सत्य का मूल्यांकन करता है, तो एक ऑब्जेक्ट हैश जहां कुंजियाँ नियंत्रण नाम और मान डेटा हैं।

10। serializeElements ()

अजाक्स अनुरोधों (डिफ़ॉल्ट व्यवहार) के लिए उपयुक्त स्ट्रिंग तत्वों के एक सरणी को सीरियलाइज़ करें या, यदि वैकल्पिक getHash सही का मूल्यांकन करता है, तो एक ऑब्जेक्ट हैश जहां कुंजियाँ प्रपत्र नियंत्रण नाम और मान डेटा हैं।

JSON का परिचय

JSON (जावास्क्रिप्ट ऑब्जेक्ट नोटेशन) एक हल्का डेटा-इंटरचेंज प्रारूप है।

  • JSON मनुष्य के लिए पढ़ना और लिखना आसान है।

  • JSON मशीनों को पार्स और जेनरेट करना आसान है।

  • JSON जावास्क्रिप्ट प्रोग्रामिंग भाषा के सबसेट पर आधारित है।

  • JSON का उपयोग पूरे वेब पर API द्वारा विशेष रूप से किया जाता है और Ajax अनुरोधों में XML का एक तेज़ विकल्प है।

  • JSON एक पाठ प्रारूप है जो पूरी तरह से स्वतंत्र भाषा है।

प्रोटोटाइप 1.5.1 और बाद के संस्करण में JSON एन्कोडिंग और पार्सिंग समर्थन की सुविधा है।

JSON एन्कोडिंग

प्रोटोटाइप एन्कोडिंग के लिए निम्नलिखित तरीके प्रदान करता है -

NOTE - सुनिश्चित करें कि कम से कम प्रोटोटाइप 1.6.js के संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। Number.toJSON ()

दिए गए नंबर के लिए JSON स्ट्रिंग देता है।

2। String.toJSON ()

दिए गए स्ट्रिंग के लिए एक JSON स्ट्रिंग लौटाता है।

3। Array.toJSON ()

दिए गए Array के लिए JSON स्ट्रिंग देता है।

4। Hash.toJSON ()

दिए गए हैश के लिए JSON स्ट्रिंग देता है।

5। Date.toJSON ()

दिनांक को JSON स्ट्रिंग (JSON द्वारा उपयोग किए गए ISO प्रारूप के बाद) में परिवर्तित करता है।

6। Object.toJSON ()

दिए गए ऑब्जेक्ट के लिए एक JSON स्ट्रिंग देता है।

यदि आप उस डेटा के प्रकार के बारे में अनिश्चित हैं जिसे आपको सांकेतिक शब्दों में बदलना है, तो आपका सबसे अच्छा शर्त Object.toJSON का उपयोग करना है -

var data = {name: 'Violet', occupation: 'character', age: 25 };
Object.toJSON(data);

यह निम्नलिखित परिणाम का उत्पादन करेगा -

'{"name": "Violet", "occupation": "character", "age": 25}'

इसके अलावा, यदि आप कस्टम ऑब्जेक्ट्स का उपयोग कर रहे हैं, तो आप अपनी स्वयं की toJSON विधि सेट कर सकते हैं, जिसका उपयोग Object.toJSON द्वारा किया जाएगा । उदाहरण के लिए -

var Person = Class.create();
Person.prototype = {
   initialize: function(name, age) {
      this.name = name;
      this.age = age;
   },  
   toJSON: function() {
      return ('My name is ' + this.name + 
         ' and I am ' + this.age + ' years old.').toJSON();
   }
};
var john = new Person('John', 49);
Object.toJSON(john);

यह निम्नलिखित परिणाम का उत्पादन करेगा -

'"My name is John and I am 49 years old."'

पार्सिंग JSON

जावास्क्रिप्ट में, JSON को पार्स करना आमतौर पर JSON स्ट्रिंग की सामग्री का मूल्यांकन करके किया जाता है। इससे निपटने के लिए प्रोटोटाइप String.evalJSON का परिचय देता है। उदाहरण के लिए -

var d='{ "name":"Violet","occupation":"character" }'.evalJSON();
d.name;

यह निम्नलिखित परिणाम का उत्पादन करेगा -

"Violet"

Ajax के साथ JSON का उपयोग करना

Ajax के साथ JSON का उपयोग करना बहुत सीधा है। बस String.evalJSON को परिवहन की प्रतिक्रिया पर भेजें।

new Ajax.Request('/some_url', {
   method:'get',
   onSuccess: function(transport) {
      var json = transport.responseText.evalJSON();
   }
});

यदि आपका डेटा एक अविश्वसनीय स्रोत से आता है, तो इसे साफ करना सुनिश्चित करें -

new Ajax.Request('/some_url', {
   method:'get',
   requestHeaders: {Accept: 'application/json'},
   onSuccess: function(transport) {
      var json = transport.responseText.evalJSON(true);
   }
});

AJAX का परिचय

AJAX के लिए खड़ा है Aएक समय का JavaScript और Xएमएल। AJAX XML, HTML, CSS और Java स्क्रिप्ट की मदद से बेहतर, तेज और अधिक इंटरैक्टिव वेब एप्लिकेशन बनाने के लिए एक नई तकनीक है।

AJAX पर पूरी तरह से समझने के लिए, कृपया हमारे सरल AJAX ट्यूटोरियल से गुजरें ।

AJAX के लिए प्रोटोटाइप समर्थन

प्रोटोटाइप फ़्रेमवर्क आपको बहुत आसान और मज़ेदार तरीके से अजाक्स कॉल से निपटने में सक्षम बनाता है जो सुरक्षित (क्रॉस-ब्राउज़र) भी है। प्रोटोटाइप भी एक स्मार्ट तरीके से डील करता है जिसमें जावास्क्रिप्ट कोड एक सर्वर से वापस आता है और पोलिंग के लिए हेल्पर क्लास प्रदान करता है।

Ajax की कार्यक्षमता वैश्विक Ajax ऑब्जेक्ट में निहित है । यह ऑब्जेक्ट AJAX अनुरोधों और प्रतिक्रियाओं को आसान तरीके से संभालने के लिए सभी आवश्यक तरीके प्रदान करता है।

AJAX का अनुरोध

Ajax.Request () ऑब्जेक्ट के उदाहरण बनाकर वास्तविक अनुरोध किए जाते हैं ।

new Ajax.Request('/some_url', { method:'get' });

पहला पैरामीटर अनुरोध का URL है; दूसरा विकल्प हैश है। विधि विकल्प का उपयोग करने के लिए HTTP विधि को संदर्भित करता है; डिफ़ॉल्ट विधि POST है।

AJAX प्रतिक्रिया कॉलबैक

अजाक्स अनुरोध डिफ़ॉल्ट अतुल्यकालिक द्वारा होता है, जिसका अर्थ है कि आपके पास कॉलबैक होना चाहिए जो एक प्रतिक्रिया से डेटा को संभाल लेगा। अनुरोध करते समय विकल्प हैश में कॉलबैक विधियों को पारित किया जाता है -

new Ajax.Request('/some_url', {
   method:'get',
   onSuccess: function(transport) {
      var response = transport.responseText || "no response text";
      alert("Success! \n\n" + response);
   },
   onFailure: function() { alert('Something went wrong...') }
});

यहाँ हैश में दो कॉलबैक दिए गए हैं -

  • onSuccess
  • onFailure

उपरोक्त दो में से किसी भी कॉल को प्रतिक्रिया की स्थिति के आधार पर कहा जाता है। दोनों के लिए दिया गया पहला पैरामीटर मूल xmlHttpRequest ऑब्जेक्ट है जिसमें से आप क्रमशः इसके responseText और responseXML गुणों का उपयोग कर सकते हैं।

आप कॉलबैक दोनों को निर्दिष्ट कर सकते हैं, एक या कोई भी - यह आपके ऊपर है। अन्य उपलब्ध कॉलबैक हैं -

  • onUninitialized
  • onLoading
  • onLoaded
  • onInteractive
  • onComplete
  • onException

वे सभी xmlHttpRequest परिवहन की एक निश्चित स्थिति से मेल खाते हैं , केवल अपवाद को छोड़कर, जो अन्य कॉलबैक भेजने के दौरान अपवाद होने पर आग लग जाती है।

NOTE- सभी ब्राउजरों द्वारा ऑन-यूनेनेटाइज्ड, ऑनलॉइडिंग, ऑन-प्ले, और ऑन-इनएक्टिव एक्टिवबैक लगातार लागू नहीं किए जाते हैं। सामान्य तौर पर, इनका उपयोग करने से बचना सबसे अच्छा है।

प्रोटोटाइप AJAX के तरीके

अजाक्स वस्तु एक आसान तरीके से AJAX अनुरोधों और प्रतिक्रियाओं को संभालने के लिए सभी आवश्यक तरीके प्रदान करता है। यहां AJAX से संबंधित सभी विधियों की पूरी सूची दी गई है।

NOTE - सुनिश्चित करें कि आपके पास कम से कम प्रोटोटाइप 1.6.js का संस्करण 1.6 है।

क्र.सं. विधि और विवरण
1। अजाक्स विकल्प

यह एक विधि नहीं है, लेकिन सभी AJAX अनुरोधकर्ताओं और कॉलबैक द्वारा साझा किए गए सभी मुख्य विकल्पों का विवरण है।

2। Ajax.PeriodicalUpdater ()

समय-समय पर एक AJAX अनुरोध करता है और प्रतिक्रिया पाठ के आधार पर कंटेनर की सामग्री को अपडेट करता है।

3। Ajax.Request ()

AJAX के अनुरोध को आरंभ और संसाधित करता है।

4। Ajax.Responders ()

वैश्विक श्रोताओं के भंडार ने प्रोटोटाइप-आधारित AJAX अनुरोधों के प्रत्येक चरण के बारे में सूचित किया।

5। Ajax.Response ()

ऑब्जेक्ट सभी अजाक्स अनुरोध कॉलबैक के पहले तर्क के रूप में पारित हुआ।

6। Ajax.Updater ()

AJAX अनुरोध करता है और प्रतिक्रिया पाठ के आधार पर कंटेनर की सामग्री को अपडेट करता है।

प्रोटोटाइप रंग मूल्यों के अंतराल का प्रतिनिधित्व करते हैं। सीमा प्राप्त करने का पसंदीदा तरीका है का उपयोग करना$R उपयोगिता समारोह।

आप एक सरल वाक्यविन्यास का उपयोग करके मानों की एक बड़ी श्रृंखला बना सकते हैं -

$R(1, 10).inspect();

$R('a', 'e').inspect();

यह निम्नलिखित परिणाम का उत्पादन करेगा -

['1, 2, 3, 4, 5, 6, 7, 8, 9, 10']

['a', 'b', 'c', 'd', 'e']

शामिल () विधि

यह विधि निर्धारित करती है कि मूल्य सीमा में शामिल है या नहीं -

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

Range.include(value);

प्रतिलाभ की मात्रा

यदि मूल्य शामिल है, तो एक सही मूल्य देता है अन्यथा गलत।

उदाहरण

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         function showResult() {
            alert ( "Test 1 : " + $R(1, 10).include(5));
            // Returns true
   
            alert ( "Test 2 : " + $R('a', 'h').include('x'));
            // Returns flase
         }
      </script>
   </head>

   <body>
      <p>Click the button to see the result.</p>
      <br />
      <br />
      <input type = "button" value = "Result" onclick = "showResult();"/>
   </body>
</html>

उत्पादन

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

PeriodicalExecuter द्वारा प्रदान किया गया लाभ यह है कि यह आपको कॉलबैक फ़ंक्शन के कई समानांतर निष्पादन के खिलाफ ढाल देता है।

एक PeriodicalExecuter बनाना

कंस्ट्रक्टर दो तर्क देता है -

  • कॉलबैक फ़ंक्शन।
  • निष्पादन के बीच अंतराल (सेकंड में)।

एक बार लॉन्च होने के बाद, एक PeriodicalExecuter अनिश्चित काल के लिए ट्रिगर हो जाता है, जब तक कि पेज अनलोड या निष्कासन रोक () विधि का उपयोग करके बंद नहीं किया जाता है।

उदाहरण

निम्नलिखित उदाहरण है जो हर 5 सेकंड के बाद एक संवाद बॉक्स को पॉप अप करेगा जब तक आप "रद्द करें" बटन दबाकर इसे रोक नहीं देंगे।

<html>
   <head>
      <title>Prototype examples</title>
      <script type = "text/javascript" src = "/javascript/prototype.js"></script>
      
      <script>
         function startExec() {
            new PeriodicalExecuter(function(pe) {
               if (!confirm('Want me to annoy you again later?'))
               pe.stop();
            }, 5);
         }
      </script>
   </head>

   <body>
      <p>Click start button to start periodic executer:</p>
      <br />
      <br />
      <input type = "button" value = "start" onclick = "startExec();"/>
   </body>
</html>

उत्पादन