JqueryUI - स्वतः पूर्ण

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

JQueryUI एक स्वत: पूर्ण विजेट प्रदान करता है - एक नियंत्रण जो एक <select> ड्रॉपडाउन की तरह बहुत काम करता है, लेकिन उन विकल्पों को प्रस्तुत करने के लिए फ़िल्टर करता है जो उपयोगकर्ता एक नियंत्रण में टाइप कर रहे हैं। jQueryUI प्रदान करता हैautocomplete() विधि इनपुट फ़ील्ड के नीचे सुझावों की एक सूची बनाने के लिए और उन्हें उपयुक्त शैली देने के लिए संबंधित तत्वों में नई सीएसएस कक्षाएं जोड़ता है।

कोई भी क्षेत्र जो इनपुट प्राप्त कर सकता है उसे ऑटोकॉम्प्लेट में परिवर्तित किया जा सकता है, अर्थात् <input> एलिमेंट्स, <textarea> एलिमेंट्स, और एलीमेंटेड एट्रिब्यूट के साथ एलीमेंट ।

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

autocomplete() विधि का उपयोग दो रूपों में किया जा सकता है -

  • $ (चयनकर्ता, संदर्भ) .आतंकवादी (विकल्प) विधि

  • $ (चयनकर्ता, संदर्भ) .आतंकवादी ("कार्रवाई", परम) विधि

$ (चयनकर्ता, संदर्भ) .आतंकवादी (विकल्प) विधि

स्वत: पूर्ण (विकल्प) विधि घोषणा करता है कि एक HTML <input> तत्व एक इनपुट फ़ील्ड कि सुझावों की एक सूची के ऊपर प्रदर्शित किया जाएगा के रूप में प्रबंधित किया जाना चाहिए। विकल्प पैरामीटर एक वस्तु है कि सुझावों की सूची उपयोगकर्ता इनपुट क्षेत्र में टाइपिंग है जब के व्यवहार निर्दिष्ट करता है।

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

$(selector, context).autocomplete (options);

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

$(selector, context).autocomplete({option1: value1, option2: value2..... });

निम्न तालिका उन विभिन्न विकल्पों को सूचीबद्ध करती है जिनका उपयोग इस विधि के साथ किया जा सकता है -

अनु क्रमांक। विकल्प और विवरण
1 जोङना

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

Option - appendTo

इस विकल्प का उपयोग मेनू में एक तत्व को जोड़ने के लिए किया जाता है। डिफ़ॉल्ट रूप से इसका मूल्य हैnull। जब मान शून्य होता है, तो इनपुट फ़ील्ड के माता-पिता को ui-front के एक वर्ग के लिए जाँच की जाएगी । यदि ui-front वर्ग के साथ एक तत्व पाया जाता है, तो मेनू को उस तत्व में जोड़ा जाएगा।

Syntax

$( ".selector" ).autocomplete({ appendTo: "#identifier" });
2 ऑटोफोकस

यह विकल्प जब सही पर सेट होता है , तो मेनू दिखाए जाने पर मेनू का पहला आइटम स्वचालित रूप से फ़ोकस हो जाएगा। डिफ़ॉल्ट रूप से इसका मूल्य हैfalse

Option - autoFocus

यह विकल्प जब सही पर सेट होता है , तो मेनू दिखाए जाने पर मेनू का पहला आइटम स्वचालित रूप से फ़ोकस हो जाएगा। डिफ़ॉल्ट रूप से इसका मूल्य हैfalse

Syntax

$( ".selector" ).autocomplete({ autoFocus: true });
3 विलंब

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

Option - delay

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

Syntax

$( ".selector" ).autocomplete({ delay: 500 });
4 विकलांग

यह विकल्प यदि निर्दिष्ट और सत्य है , तो स्वतः पूर्ण विजेट प्रारंभ में अक्षम है। डिफ़ॉल्ट रूप से इसका मूल्य हैfalse

Option - disabled

यह विकल्प यदि निर्दिष्ट और सत्य है , तो स्वतः पूर्ण विजेट प्रारंभ में अक्षम है। डिफ़ॉल्ट रूप से इसका मूल्य हैfalse

Syntax

$( ".selector" ).autocomplete({ disabled: true });
5 MINLENGTH

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

Option - minLength

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

Syntax

$( ".selector" ).autocomplete({ minLength: 0 });
6 पद

यह विकल्प संबंधित इनपुट तत्व के संबंध में सुझाव मेनू की स्थिति की पहचान करता है। के इनपुट तत्व करने के लिए विकल्प चूक, लेकिन आप के खिलाफ पद के लिए एक और तत्व निर्दिष्ट कर सकते हैं। डिफ़ॉल्ट रूप से इसका मूल्य है{ my: "left top", at: "left bottom", collision: "none" }

Option - position

यह विकल्प संबंधित इनपुट तत्व के संबंध में सुझाव मेनू की स्थिति की पहचान करता है। के इनपुट तत्व करने के लिए विकल्प चूक, लेकिन आप के खिलाफ पद के लिए एक और तत्व निर्दिष्ट कर सकते हैं। डिफ़ॉल्ट रूप से इसका मूल्य है{ my: "left top", at: "left bottom", collision: "none" }

Syntax

$( ".selector" ).autocomplete({ position: { my : "right top", at: "right bottom" } });
7 स्रोत

यह विकल्प उस तरीके को निर्दिष्ट करता है जिसमें इनपुट डेटा से मेल खाने वाला डेटा प्राप्त होता है। एक मान प्रदान किया जाना चाहिए या स्वत: पूर्ण विजेट नहीं बनाया जाएगा। डिफ़ॉल्ट रूप से इसका मूल्य हैnone; must be specified

Option - source

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

  • String सर्वर संसाधन के URL का प्रतिनिधित्व करना जो मिलान डेटा लौटाएगा,

  • an array स्थानीय डेटा जिसमें से मान का मिलान किया जाएगा, या

  • a function जो मिलान मूल्यों को प्रदान करने से एक सामान्य कॉलबैक के रूप में कार्य करता है।

Syntax

$( ".selector" ).autocomplete({ source: [ "c++", "java", "php", "coldfusion", "javascript", "asp", "ruby" ] });

निम्न अनुभाग आपको स्वतः पूर्ण विजेट कार्यक्षमता के कुछ कार्य उदाहरण दिखाएगा।

डिफ़ॉल्ट कार्यशीलता

निम्न उदाहरण स्वत: पूर्ण विजेट कार्यक्षमता का एक सरल उदाहरण प्रदर्शित करता है, जिसमें कोई पैरामीटर नहीं है autocomplete() तरीका।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() { var availableTutorials = [ "ActionScript", "Bootstrap", "C", "C++", ]; $( "#automplete-1" ).autocomplete({
               source: availableTutorials
            });
         });
      </script>
   </head>
   
   <body>
      <!-- HTML --> 
      <div class = "ui-widget">
         <p>Type "a" or "s"</p>
         <label for = "automplete-1">Tags: </label>
         <input id = "automplete-1">
      </div>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट देखना चाहिए। अब, आप परिणाम के साथ खेल सकते हैं -

ऑटोफोकस का उपयोग

निम्न उदाहरण विकल्प के उपयोग को दर्शाता है autoFocus JqueryUI के स्वत: पूर्ण विजेट में।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() { var availableTutorials = [ "ActionScript", "Bootstrap", "C", "C++", ]; $( "#automplete-2" ).autocomplete({
               source: availableTutorials,
               autoFocus:true
            });
         });
      </script>
   </head>
   
   <body>
      <!-- HTML --> 
      <div class = "ui-widget">
         <p>Type "a" or "s"</p>
         <label for = "automplete-2">Tags: </label>
         <input id = "automplete-2">
      </div>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट भी देखना होगा। अब, आप परिणाम के साथ खेल सकते हैं -

मिनिमल और देरी का उपयोग

निम्न उदाहरण दो विकल्पों के उपयोग को प्रदर्शित करता है minLength तथा delay JqueryUI के स्वत: पूर्ण विजेट में।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() { var availableTutorials = [ "ActionScript", "Bootstrap", "C", "C++", "Ecommerce", "Jquery", "Groovy", "Java", "JavaScript", "Lua", "Perl", "Ruby", "Scala", "Swing", "XHTML" ]; $( "#automplete-3" ).autocomplete({
               minLength:2,   
               delay:500,   
               source: availableTutorials
            });
         });
      </script>
   </head>
   
   <body>
      <!-- HTML --> 
      <div class = "ui-widget">
         <p>Type two letter for e.g:ja,sc etc</p>
         <label for = "automplete-3">Tags: </label>
         <input id = "automplete-3">
      </div>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट भी देखना होगा। अब, आप परिणाम के साथ खेल सकते हैं -

लेबल का उपयोग

निम्न उदाहरण विकल्प के उपयोग को दर्शाता है label JqueryUI के स्वत: पूर्ण विजेट में।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() { $( "#autocomplete-4" ).autocomplete({
               source: [
                  { label: "India", value: "IND" },
                  { label: "Australia", value: "AUS" }
               ]
            });
         });
      </script>
   </head>
   
   <body>
      <!-- HTML --> 
      <div class = "ui-widget">
         <p>Type I OR A</p>
         <input id = "autocomplete-4">
      </div>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट भी देखना होगा। अब, आप परिणाम के साथ खेल सकते हैं -

बाहरी स्रोत का उपयोग

निम्न उदाहरण के लिए बाहरी फ़ाइल के उपयोग को दर्शाता है source JqueryUI के स्वत: पूर्ण विजेट में विकल्प।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() { $( "#autocomplete-5" ).autocomplete({
               source: "/jqueryui/search.php",
               minLength: 2
            });
         });
      </script> 
   </head>
   
   <body>
      <input id = "autocomplete-5">
   </body>
</html>

फ़ाइल search.php को उपरोक्त फ़ाइल (autocompleteexample.html) के समान स्थान पर रखा गया है। खोज की सामग्री। एफपी इस प्रकार हैं -

<?
$term = $_GET[ "term" ];
$companies = array( array( "label" => "JAVA", "value" => "1" ), array( "label" => "DATA IMAGE PROCESSING", "value" => "2" ), array( "label" => "JAVASCRIPT", "value" => "3" ), array( "label" => "DATA MANAGEMENT SYSTEM", "value" => "4" ), array( "label" => "COMPUTER PROGRAMMING", "value" => "5" ), array( "label" => "SOFTWARE DEVELOPMENT LIFE CYCLE", "value" => "6" ), array( "label" => "LEARN COMPUTER FUNDAMENTALS", "value" => "7" ), array( "label" => "IMAGE PROCESSING USING JAVA", "value" => "8" ), array( "label" => "CLOUD COMPUTING", "value" => "9" ), array( "label" => "DATA MINING", "value" => "10" ), array( "label" => "DATA WAREHOUSE", "value" => "11" ), array( "label" => "E-COMMERCE", "value" => "12" ), array( "label" => "DBMS", "value" => "13" ), array( "label" => "HTTP", "value" => "14" ) ); $result = array();
foreach ($companies as $company) {
   $companyLabel = $company[ "label" ];
   if ( strpos( strtoupper($companyLabel), strtoupper($term) )!== false ) {
      array_push( $result, $company );
   }
}

echo json_encode( $result );
?>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट भी देखना होगा। अब, आप परिणाम के साथ खेल सकते हैं -

उदाहरण के लिए दो अक्षर शब्द टाइप करें: ja, sc आदि

$ (चयनकर्ता, संदर्भ) .आतंकवादी ("कार्रवाई", परम) विधि

स्वत: पूर्ण ( "कार्रवाई", पैरामीटर) विधि इस तरह के शो या छिपाने के रूप में सुझाव, की सूची पर कोई क्रिया कर सकते हैं। कार्रवाई को पहले तर्क में स्ट्रिंग के रूप में निर्दिष्ट किया गया है (उदाहरण के लिए, सूची को छिपाने के लिए "करीब")। निम्न तालिका में पारित किए जा सकने वाले कार्यों को देखें।

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

$(selector, context).autocomplete ("action", params);;

निम्न तालिका उन विभिन्न क्रियाओं को सूचीबद्ध करती है जिनका उपयोग इस विधि के साथ किया जा सकता है -

अनु क्रमांक। कार्रवाई और विवरण
1 बंद करे

यह क्रिया स्वतः पूर्ण मेनू में सुझावों की सूची छिपाती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Action - close

यह क्रिया स्वतः पूर्ण मेनू में सुझावों की सूची छिपाती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Syntax

$( ".selector" ).autocomplete("close");
2 नष्ट

यह क्रिया स्वतः पूर्ण कार्यक्षमता को निकाल देती है। सुझावों की सूची हटा दी जाती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Action - destroy

यह क्रिया स्वतः पूर्ण कार्यक्षमता को निकाल देती है। सुझावों की सूची हटा दी जाती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Syntax

$( ".selector" ).autocomplete("destroy");
3 अक्षम

यह क्रिया स्वत: पूर्णता तंत्र को निष्क्रिय कर देती है। सुझावों की सूची अब प्रकट नहीं होती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Action - disable

यह क्रिया स्वत: पूर्णता तंत्र को निष्क्रिय कर देती है। सुझावों की सूची अब प्रकट नहीं होती है। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Syntax

$( ".selector" ).autocomplete("disable");
4 सक्षम

यह क्रिया स्वत: पूर्णता तंत्र को पुनः सक्रिय करती है। सुझावों की सूची फिर से प्रदर्शित की जाएगी। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Action - enable

यह क्रिया स्वत: पूर्णता तंत्र को पुनः सक्रिय करती है। सुझावों की सूची फिर से प्रदर्शित की जाएगी। यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

Syntax

$( ".selector" ).autocomplete("enable");
5 विकल्प (विकल्पनाम)

यह क्रिया निर्दिष्ट परम विकल्प का मान निकालती है । यह विकल्प स्वतः पूर्ण (विकल्प) के साथ उपयोग किए जाने वालों में से एक से मेल खाता है।

Action - option( optionName )

यह क्रिया निर्दिष्ट परम विकल्प का मान निकालती है । यह विकल्प स्वतः पूर्ण (विकल्प) के साथ उपयोग किए जाने वालों में से एक से मेल खाता है।

Syntax

var isDisabled = $( ".selector" ).autocomplete( "option", "disabled" );
6 विकल्प

इस क्रिया को वर्तमान स्वत: पूर्ण विकल्प हैश का प्रतिनिधित्व करने वाली कुंजी / मान जोड़े वाली एक वस्तु मिलती है।

Action - option

इस क्रिया को वर्तमान स्वत: पूर्ण विकल्प हैश का प्रतिनिधित्व करने वाली कुंजी / मान जोड़े वाली एक वस्तु मिलती है।

Syntax

var options = $( ".selector" ).autocomplete( "option" );
7 विकल्प (विकल्पनाम, मान)

यह क्रिया निर्दिष्ट विकल्प के साथ जुड़े स्वत: पूर्ण विकल्प का मान निर्धारित करती है । तर्क विकल्पनाम सेट किए जाने वाले विकल्प का नाम है और विकल्प के लिए निर्धारित मूल्य मान है।

Action - option( optionName, value )

यह क्रिया निर्दिष्ट विकल्प के साथ जुड़े स्वत: पूर्ण विकल्प का मान निर्धारित करती है । तर्क विकल्पनाम सेट किए जाने वाले विकल्प का नाम है और विकल्प के लिए निर्धारित मूल्य मान है।

Syntax

$( ".selector" ).autocomplete( "option", "disabled", true );
8 विकल्प (विकल्प)

यह क्रिया स्वतः पूर्ण के लिए एक या अधिक विकल्प सेट करती है। तर्क विकल्प सेट करने के लिए विकल्प-मूल्य जोड़े का एक नक्शा है।

Action - option( options )

यह क्रिया स्वतः पूर्ण के लिए एक या अधिक विकल्प सेट करती है। तर्क विकल्प सेट करने के लिए विकल्प-मूल्य जोड़े का एक नक्शा है।

Syntax

$( ".selector" ).autocomplete( "option", { disabled: true } );
9 खोज ([मूल्य])

यह क्रिया स्ट्रिंग मान और डेटा स्रोत ( options.source में निर्दिष्ट ) के बीच पत्राचार की खोज करती है । वर्णों की न्यूनतम संख्या ( विकल्पों में इंगित की गई ।minLength ) मूल्य में पहुंचा जाना चाहिए, अन्यथा खोज निष्पादित नहीं की जाती है।

Action - search( [value ] )

यह क्रिया स्ट्रिंग मान और डेटा स्रोत ( options.source में निर्दिष्ट ) के बीच पत्राचार की खोज करती है । वर्णों की न्यूनतम संख्या ( विकल्पों में इंगित की गई ।minLength ) मूल्य में पहुंचा जाना चाहिए, अन्यथा खोज निष्पादित नहीं की जाती है।

Syntax

$( ".selector" ).autocomplete( "search", "" );
10 विजेट

सुझावों की सूची के अनुरूप <ul> DOM तत्व प्राप्त करें। यह jQuery वर्ग की एक वस्तु है जो jQuery के चयनकर्ताओं का उपयोग किए बिना सूची तक आसान पहुंच की अनुमति देता है।

Action - widget

सुझावों की सूची के अनुरूप <ul> DOM तत्व प्राप्त करें। यह jQuery वर्ग की एक वस्तु है जो jQuery के चयनकर्ताओं का उपयोग किए बिना सूची तक आसान पहुंच की अनुमति देता है।

Syntax

$( ".selector" ).autocomplete("widget");

उदाहरण

अब हम उपरोक्त तालिका से क्रियाओं का उपयोग करके एक उदाहरण देखते हैं। निम्न उदाहरण विकल्प (विकल्पनाम, मान) विधि के उपयोग को प्रदर्शित करता है ।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <!-- Javascript -->
      <script>
         $(function() {
            var availableTutorials = [
               "ActionScript",
               "Bootstrap",
               "C",
               "C++",
               "Ecommerce",
               "Jquery",
               "Groovy",
               "Java",
               "JavaScript",
               "Lua",
               "Perl",
               "Ruby",
               "Scala",
               "Swing",
               "XHTML"	
            ];
            $( "#automplete-6" ).autocomplete({ source: availableTutorials }); $( "#automplete-6" ).autocomplete("option", "position",
               { my : "right-10 top+10", at: "right top" }) 
         });
      </script>
   </head>
   
   <body>
      <!-- HTML --> 
      <div class = "ui-widget">
         <p>Type "a" or "s"</p>
         <label for = "automplete-6">Tags: </label>
         <input id = "automplete-6">
      </div>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htm और इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है, आपको निम्न आउटपुट भी देखना होगा -

एक्सटेंशन पॉइंट्स

स्वतः पूर्ण विजेट को विजेट कारखाने के साथ निर्मित किया जा सकता है। विगेट्स का विस्तार करते समय, आपके पास मौजूदा तरीकों के व्यवहार को ओवरराइड या जोड़ने की क्षमता होती है। निम्न तालिका उन विधियों को सूचीबद्ध करती है जो ऊपर बताए गए प्लगइन तरीकों के समान एक्सटेंशन स्थिरता के साथ विस्तार बिंदुओं के रूप में कार्य करती हैं ।

अनु क्रमांक। विधि और विवरण
1 _renderItem (उल, आइटम)

यह विधि विजेट के मेनू में प्रत्येक विकल्प के निर्माण को नियंत्रित करती है। यह विधि एक नया <li> तत्व बनाता है, इसे मेनू में जोड़ता है और इसे वापस करता है।

_renderItem( ul, item )

यह विधि विजेट के मेनू में प्रत्येक विकल्प के निर्माण को नियंत्रित करती है। यह विधि एक नया <li> तत्व बनाता है, इसे मेनू में जोड़ता है और इसे वापस करता है। कहाँ -

  • <ul> वह तत्व है जिसे नए बनाए गए <li> तत्व से जोड़ा जाना चाहिए।

  • item

    एक लेबल (स्ट्रिंग) , आइटम के लिए प्रदर्शित करने के लिए स्ट्रिंग, या एक मूल्य (स्ट्रिंग) हो सकता है , आइटम का चयन करने पर इनपुट में डालने का मूल्य।
2 _renderMenu (उल, आइटम)

यह विधि विजेट के मेनू के निर्माण को नियंत्रित करती है।

_renderMenu( ul, items )

यह विधि विजेट के मेनू के निर्माण को नियंत्रित करती है। कहाँ -

  • <ul>आइटम का एक सरणी है जो उपयोगकर्ता के टाइप किए गए शब्द से मेल खाता है। प्रत्येक वस्तु लेबल और मूल्य गुणों वाली एक वस्तु है ।

3 _resizeMenu ()

यह विधि प्रदर्शित होने से पहले मेनू को आकार देने को नियंत्रित करती है । मेनू तत्व इस पर उपलब्ध है । menu.element यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

_resizeMenu()

यह विधि प्रदर्शित होने से पहले मेनू को आकार देने को नियंत्रित करती है । मेनू तत्व इस पर उपलब्ध है । menu.element यह विधि किसी भी तर्क को स्वीकार नहीं करती है।

स्वत: पूर्ण तत्वों पर इवेंट मैनेजमेंट

स्व-पूर्ण (विकल्प) विधि के अलावा जो हमने पिछले खंडों में देखी थी, JqueryUI इवेंट विधियों को प्रदान करता है जो किसी विशेष घटना के लिए ट्रिगर हो जाता है। ये घटना विधियाँ नीचे सूचीबद्ध हैं -

अनु क्रमांक। घटना विधि और विवरण
1 परिवर्तन (घटना, यूआई)

चयन के आधार पर <इनपुट> तत्व का मान बदल जाने पर यह घटना शुरू हो जाती है। जब ट्रिगर किया जाता है, तो यह घटना हमेशा नज़दीकी घटना ट्रिगर होने के बाद आएगी ।

Event - change(event, ui)

चयन के आधार पर <इनपुट> तत्व का मान बदल जाने पर यह घटना शुरू हो जाती है। जब ट्रिगर किया जाता है, तो यह घटना हमेशा नज़दीकी घटना ट्रिगर होने के बाद आएगी । जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता हैयूआई के संभावित मूल्य हैं -

  • item- मेनू से चयनित आइटम, यदि कोई हो। अन्यथा संपत्ति शून्य है।

Syntax

$( ".selector" ).autocomplete({
   change: function( event, ui ) {}
});
2 करीब (घटना, यूआई)

जब भी स्वतः पूर्ण मेनू बंद हो जाता है, तो यह घटना शुरू हो जाती है।

Event - close(event, ui)

जब भी स्वतः पूर्ण मेनू बंद हो जाता है, तो यह घटना शुरू हो जाती है। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता है

Syntax

$( ".selector" ).autocomplete({
   close: function( event, ui ) {}
});
3 बनाएं (ईवेंट, यूआई)

स्वत: पूर्ण होने पर यह घटना शुरू हो जाती है।

Event - create(event, ui)

स्वत: पूर्ण होने पर यह ईवेंट ट्रिगर हो जाता है .. जहाँ ईवेंट प्रकार ईवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता हैयूआई के संभावित मूल्य हैं -

  • item- मेनू से चयनित आइटम, यदि कोई हो। अन्यथा संपत्ति शून्य है।

Syntax

$( ".selector" ).autocomplete({
   create: function( event, ui ) {}
});
4 फोकस (घटना, यूआई)

जब भी मेनू विकल्पों में से कोई एक फोकस प्राप्त करता है तो यह घटना शुरू हो जाती है। जब तक रद्द नहीं किया जाता है (उदाहरण के लिए, गलत रिटर्न करके), ध्यान केंद्रित मूल्य <इनपुट> तत्व में सेट किया गया है।

Event - focus(event, ui)

जब भी मेनू विकल्पों में से कोई एक फोकस प्राप्त करता है तो यह घटना शुरू हो जाती है। जब तक रद्द नहीं किया जाता है (उदाहरण के लिए, गलत रिटर्न करके), ध्यान केंद्रित मूल्य <इनपुट> तत्व में सेट किया गया है। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता हैयूआई के संभावित मूल्य हैं -

  • item - केंद्रित वस्तु।

Syntax

$( ".selector" ).autocomplete({
   focus: function( event, ui ) {}
});
5 खुला (घटना, ui)

यह घटना डेटा पढ़ने के बाद चालू हो जाती है और मेनू खुलने वाला है।

Event - open(event, ui)

यह घटना डेटा पढ़ने के बाद चालू हो जाती है और मेनू खुलने वाला है। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता है

Syntax

$( ".selector" ).autocomplete({
   open: function( event, ui ) {}
});
6 प्रतिक्रिया (घटना, यूआई)

मेन्यू दिखाए जाने से पहले यह घटना खोज पूर्ण होने के बाद चालू हो जाती है। खोज पूरा होने पर यह घटना हमेशा चालू रहती है, भले ही मेनू नहीं दिखाया जाएगा क्योंकि कोई परिणाम नहीं हैं या स्वत: पूर्ण अक्षम है।

Event - response(event, ui)

मेन्यू दिखाए जाने से पहले यह घटना खोज पूर्ण होने के बाद चालू हो जाती है। खोज पूरा होने पर यह घटना हमेशा चालू रहती है, भले ही मेनू नहीं दिखाया जाएगा क्योंकि कोई परिणाम नहीं हैं या स्वत: पूर्ण अक्षम है। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता हैयूआई के संभावित मूल्य हैं -

  • content - प्रतिक्रिया डेटा होता है और जो परिणाम दिखाए जाएंगे उन्हें बदलने के लिए संशोधित किया जा सकता है।

Syntax

$( ".selector" ).autocomplete({
   response: function( event, ui ) {}
});
7 खोज (घटना, यूआई)

यह घटना किसी भी देरी और minLength मानदंडों को पूरा करने के बाद शुरू होती है, स्रोत द्वारा निर्दिष्ट तंत्र सक्रिय होने से पहले। यदि रद्द किया जाता है, तो तलाशी अभियान रद्द कर दिया जाता है।

Event - search(event, ui)

यह घटना किसी भी देरी और minLength मानदंडों को पूरा करने के बाद शुरू होती है, स्रोत द्वारा निर्दिष्ट तंत्र सक्रिय होने से पहले। यदि रद्द किया जाता है, तो तलाशी अभियान रद्द कर दिया जाता है। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता है

Syntax

$( ".selector" ).autocomplete({
   search: function( event, ui ) {}
});
8 चयन करें (ईवेंट, यूआई)

यह घटना तब चालू होती है जब किसी मूल्य को स्वतः पूर्ण मेनू से चुना जाता है। इस ईवेंट को रद्द करने से मान <इनपुट> तत्व में सेट होने से रोकता है (लेकिन मेनू को बंद होने से नहीं रोकता है)।

Event - select(event, ui)

यह घटना तब चालू होती है जब किसी मूल्य को स्वतः पूर्ण मेनू से चुना जाता है। इस ईवेंट को रद्द करने से मान <इनपुट> तत्व में सेट होने से रोकता है (लेकिन मेनू को बंद होने से नहीं रोकता है)। जहां इवेंट टाइप इवेंट का होता है , और यूआई टाइप ऑब्जेक्ट का होता हैयूआई के संभावित मूल्य हैं -

  • item - चयनित विकल्प के लिए लेबल और मूल्य गुणों वाली एक वस्तु।

Syntax

$( ".selector" ).autocomplete({
   select: function( event, ui ) {}
});

उदाहरण

निम्न उदाहरण स्वतः पूर्ण विजेट में ईवेंट विधि के उपयोग को प्रदर्शित करता है। यह उदाहरण घटनाओं के फोकस , और चयन के उपयोग को प्रदर्शित करता है ।

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery UI Autocomplete functionality</title>
      <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"
         rel = "stylesheet">
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
      <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
      
      <style>
         #project-label {
            display: block;
            font-weight: bold;
            margin-bottom: 1em;
         }
         #project-icon {
            float: left;
            height: 32px;
            width: 32px;
         }
         #project-description {
            margin: 0;
            padding: 0;
         }
      </style>
      
      <!-- Javascript -->
      <script>
         $(function() { var projects = [ { value: "java", label: "Java", desc: "write once run anywhere", }, { value: "jquery-ui", label: "jQuery UI", desc: "the official user interface library for jQuery", }, { value: "Bootstrap", label: "Twitter Bootstrap", desc: "popular front end frameworks ", } ]; $( "#project" ).autocomplete({
               minLength: 0,
               source: projects,
               focus: function( event, ui ) {
                  $( "#project" ).val( ui.item.label ); return false; }, select: function( event, ui ) { $( "#project" ).val( ui.item.label );
                  $( "#project-id" ).val( ui.item.value ); $( "#project-description" ).html( ui.item.desc );
                  return false;
               }
            })
				
            .data( "ui-autocomplete" )._renderItem = function( ul, item ) {
               return $( "<li>" )
               .append( "<a>" + item.label + "<br>" + item.desc + "</a>" )
               .appendTo( ul );
            };
         });
      </script>
   </head>
   
   <body>
      <div id = "project-label">Select a project (type "a" for a start):</div>
      <input id = "project">
      <input type = "hidden" id = "project-id">
      <p id = "project-description"></p>
   </body>
</html>

हमें एक HTML फ़ाइल में उपरोक्त कोड को बचाने के लिए autocompleteexample.htmऔर इसे एक मानक ब्राउज़र में खोलें जो जावास्क्रिप्ट का समर्थन करता है। आपको निम्न आउटपुट भी देखना होगा -