MooTools - नियमित अभिव्यक्ति

MooTools नियमित अभिव्यक्ति (regex) बनाने और उपयोग करने का एक तरीका प्रदान करता है। यह ट्यूटोरियल रीजेक्स के मूल और चरम उपयोगों की व्याख्या करेगा।

आइए हम नियमित अभिव्यक्ति के कुछ तरीकों पर चर्चा करें।

परीक्षा()

परीक्षण () इनपुट स्ट्रिंग के साथ नियमित अभिव्यक्ति का परीक्षण करने के लिए उपयोग की जाने वाली विधि है। जबकि जावास्क्रिप्ट परीक्षण () फ़ंक्शन के साथ पहले से ही RegExp ऑब्जेक्ट प्रदान करता है, MooTools RegExp ऑब्जेक्ट में अधिक सुविधाएँ जोड़ता है। आइए एक उदाहरण लेते हैं और समझते हैं कि परीक्षण () विधि का उपयोग कैसे करें। निम्नलिखित कोड पर एक नज़र डालें।

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex').addEvent('click', regex_demo);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp: <input type = "text" id = "regex_match"/><br/><br/>
      <input type = "button" id = "regex" value = "TEST"/><br/><br/>
      <Lable id = "regex_1_result"></Lable>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन

मामले की अनदेखी करें

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

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match').get('value');
            var test_result = test_string.test(regex_value, "i");
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex').addEvent('click', regex_demo);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp: <input type = "text" id = "regex_match"/><br/><br/>
      <input type = "button" id = "regex" value = "TEST"/><br/><br/>
      <Lable id = "regex_1_result"></Lable>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन

रेगेक्स '^' से शुरू होता है

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

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex').addEvent('click', regex_demo);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp: <input type = "text" id = "regex_match"/><br/><br/>
      <input type = "button" id = "regex" value = "Match"/><br/><br/>
      <Lable id = "regex_1_result"></Lable>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन

Regex '$' के साथ समाप्त होता है

रेगेक्स '$' (डॉलर) एक विशेष ऑपरेटर है जो आपको किसी दिए गए स्ट्रिंग के अंत में नियमित अभिव्यक्ति की जांच करने की अनुमति देता है। इस ऑपरेटर को नियमित अभिव्यक्ति के लिए प्रत्यय के रूप में उपयोग किया जाता है। आइए एक उदाहरण लेते हैं जो बताएगा कि इस ऑपरेटर का उपयोग कैसे करें। निम्नलिखित कोड पर एक नज़र डालें।

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex').addEvent('click', regex_demo);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp: <input type = "text" id = "regex_match"/><br/><br/>
      <input type = "button" id = "regex" value = "Match"/><br/><br/>
      <Lable id = "regex_1_result"></Lable>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन

चरित्र वर्ग

चरित्र वर्ग नियमित अभिव्यक्तियों का एक चरण है जो आपको विशिष्ट वर्णों (ए या जेड) या वर्णों की श्रेणी (ए - जेड) से मेल खाने की अनुमति देता है। उदाहरण के लिए, आप परीक्षण करना चाहते हैं कि दोनों में से कोई भी शब्द foo और zoo एक स्ट्रिंग में मौजूद हैं या नहीं, कक्षाएं आपको नियमित अभिव्यक्तियों के साथ बॉक्स कोष्ठक [] में वर्णों को रखकर ऐसा करने की अनुमति देती हैं। निम्नलिखित कोड पर एक नज़र डालें।

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo_1 = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match_1').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         var regex_demo_2 = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match_2').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_2_result').set('html', "Matched");
            } else {
               $('regex_2_result').set('html', "Not Match");
            }
         }
         
         var regex_demo_3 = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match_3').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_3_result').set('html', "Matched");
            } else {
               $('regex_3_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex_1').addEvent('click', regex_demo_1);
            $('regex_2').addEvent('click', regex_demo_2);
            $('regex_3').addEvent('click', regex_demo_3);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp 1: <input type = "text" id = "regex_match_1"/> 
      <input type = "button" id = "regex_1" value = "Match"/> 
      <Lable id = "regex_1_result"></Lable><br/><br/>
      
      Reg Exp 2: <input type = "text" id = "regex_match_2"/> 
      <input type = "button" id = "regex_2" value = "Match"/> 
      <Lable id = "regex_2_result"></Lable><br/><br/>
      
      Reg Exp 3: <input type = "text" id = "regex_match_3"/> 
      <input type = "button" id = "regex_3" value = "Match"/> 
      <Lable id = "regex_3_result"></Lable>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन

escapeRegExp ()

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

- . * + ? ^ $ { } ( ) | [ ] / \

एक उदाहरण लेते हैं जिसमें, हमारे पास एक स्ट्रिंग है जैसे "[चेक-इस-सामान] यह $ 900 है।" यदि आप इस पूरे स्ट्रिंग को लेना चाहते हैं, तो आपको इसे इस तरह घोषित करना होगा - "\ [check \ -this \ -stuff \" यह \ $ 900 है। " सिस्टम केवल इस पैटर्न को स्वीकार करता है। हम MooTools में एस्कैप चरित्र पैटर्न का उपयोग नहीं करते हैं। हमारे पास भागने के पात्रों को अनदेखा करने के लिए भागने की विधि () विधि है। निम्नलिखित कोड पर एक नज़र डालें।

उदाहरण

<!DOCTYPE html>
<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">
         var regex_demo_1 = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match_1').get('value');
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_1_result').set('html', "Matched");
            } else {
               $('regex_1_result').set('html', "Not Match");
            }
         }
         
         var regex_demo_2 = function(){
            var test_string = $('regex_value').get('value');
            var regex_value = $('regex_match_1').get('value');
            regex_value = regex_value.escapeRegExp();
            var test_result = test_string.test(regex_value);
            
            if (test_result){
               $('regex_2_result').set('html', "Matched");
            } else {
               $('regex_2_result').set('html', "Not Match");
            }
         }
         
         window.addEvent('domready', function() {
            $('regex_1').addEvent('click', regex_demo_1);
            $('regex_2').addEvent('click', regex_demo_2);
            $('regex_3').addEvent('click', regex_demo_3);
         });
      </script>
   </head>
   
   <body>
      String: <input type = "text" id = "regex_value"/><br/><br/>
      Reg Exp 1: <input type = "text" id = "regex_match_1" size = "6"/><br/><br/>
      <input type = "button" id = "regex_1" value = "With escapeRegExp()"/> 
      <Lable id = "regex_1_result"></Lable><br/><br/>
      <input type = "button" id = "regex_2" value = "Without escapeRegExp()"/> 
      <Lable id = "regex_2_result"></Lable><br/><br/>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे -

उत्पादन