कोणीय सामग्री - स्वतः पूर्ण

md-autocomplete, एक कोणीय निर्देश, एक विशेष इनपुट नियंत्रण के रूप में एक इनबिल्ट ड्रॉपडाउन के साथ एक कस्टम क्वेरी के लिए सभी संभव मैचों को दिखाने के लिए उपयोग किया जाता है। यह नियंत्रण इनपुट क्षेत्र में उपयोगकर्ता के प्रकार के रूप में वास्तविक समय सुझाव बॉक्स के रूप में कार्य करता है।<md-autocomplete>स्थानीय या दूरस्थ डेटा स्रोतों से खोज परिणाम प्रदान करने के लिए उपयोग किया जा सकता है। md-autocomplete caches एक क्वेरी करते समय परिणाम देता है। पहले कॉल के बाद, यह अनावश्यक सर्वर अनुरोधों या लुकअप लॉजिक को समाप्त करने के लिए कैश्ड परिणामों का उपयोग करता है और इसे अक्षम किया जा सकता है।

गुण

निम्नलिखित तालिका मापदंडों और विभिन्न विशेषताओं के विवरण को सूचीबद्ध करती है md-autocomplete

अनु क्रमांक पैरामीटर और विवरण
1

* md-items

आपकी खोज के लिए मिलान से अधिक पुनरावृति करने के लिए आइटम में आइटम के प्रारूप में एक अभिव्यक्ति।

2

md-selected-item-change

हर बार एक नए आइटम को चलाने के लिए एक अभिव्यक्ति का चयन किया जाता है।

3

md-search-text-change

हर बार खोज पाठ अपडेट को चलाने के लिए एक अभिव्यक्ति।

4

md-search-text

खोज क्वेरी पाठ को बाइंड करने के लिए एक मॉडल।

5

md-selected-item

चयनित आइटम को बाइंड करने के लिए एक मॉडल।

6

md-item-text

एक अभिव्यक्ति जो आपकी वस्तु को एकल स्ट्रिंग में बदल देगी।

7

placeholder

प्लेसहोल्डर पाठ जो इनपुट के लिए अग्रेषित किया जाएगा।

8

md-no-cache

स्वत: पूर्ण में होने वाले आंतरिक कैशिंग को अक्षम करता है।

9

ng-disabled

यह निर्धारित करता है कि इनपुट क्षेत्र को अक्षम करना है या नहीं।

10

md-min-length

स्वत: पूर्ण होने से पहले पाठ की न्यूनतम लंबाई निर्दिष्ट करता है।

1 1

md-delay

परिणामों की तलाश से पहले प्रतीक्षा करने के लिए समय (मिलीसेकंड में) की मात्रा निर्दिष्ट करता है।

12

md-autofocus

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

13

md-autoselect

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

14

md-menu-class

यह स्टाइल के लिए ड्रॉपडाउन मेनू पर लागू किया जाएगा।

15

md-floating-label

यह स्वत: पूर्ण में एक फ्लोटिंग लेबल जोड़ देगा और इसे md-input-कंटेनर में लपेट देगा।

16

md-input-name

FormController के साथ प्रयोग किए जाने वाले इनपुट तत्व को दिया गया नाम विशेषता।

17

md-input-id

इनपुट तत्व में एक आईडी जोड़ी जानी चाहिए।

18

md-input-minlength

सत्यापन के लिए इनपुट के मूल्य के लिए न्यूनतम लंबाई।

19

md-input-maxlength

सत्यापन के लिए इनपुट के मूल्य के लिए अधिकतम लंबाई।

20

md-select-on-match

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

उदाहरण

निम्नलिखित उदाहरण के उपयोग को दर्शाता है md-autocomplete निर्देशन और स्वत: पूर्ण का उपयोग भी।

am_autocomplete.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      
		<script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('autoCompleteController', autoCompleteController);

         function autoCompleteController ($timeout, $q, $log) {
            var self = this;
            self.simulateQuery = false;
            self.isDisabled    = false;
            
            // list of states to be displayed
            self.states        = loadStates();
            self.querySearch   = querySearch;
            self.selectedItemChange = selectedItemChange;
            self.searchTextChange   = searchTextChange;
            self.newState = newState;
            
            function newState(state) {
               alert("This functionality is yet to be implemented!");
            }
            
            function querySearch (query) {
               var results = query ? self.states.filter( createFilterFor(query) ) :
                  self.states, deferred;
                  
               if (self.simulateQuery) {
                  deferred = $q.defer();
                     
                  $timeout(function () { 
                     deferred.resolve( results ); 
                  }, 
                  Math.random() * 1000, false);
                  return deferred.promise;
               } else {
                  return results;
               }
            }
            function searchTextChange(text) {
               $log.info('Text changed to ' + text);
            }
            function selectedItemChange(item) {
               $log.info('Item changed to ' + JSON.stringify(item));
            }
            
            //build list of states as map of key-value pairs
            function loadStates() {
               var allStates = 'Alabama, Alaska, Arizona, Arkansas, California, Colorado, Connecticut, Delaware,\
                  Florida, Georgia, Hawaii, Idaho, Illinois, Indiana, Iowa, Kansas, Kentucky, Louisiana,\
                  Maine, Maryland, Massachusetts, Michigan, Minnesota, Mississippi, Missouri, Montana,\
                  Nebraska, Nevada, New Hampshire, New Jersey, New Mexico, New York, North Carolina,\
                  North Dakota, Ohio, Oklahoma, Oregon, Pennsylvania, Rhode Island, South Carolina,\
                  South Dakota, Tennessee, Texas, Utah, Vermont, Virginia, Washington, West Virginia,\
                  Wisconsin, Wyoming';
                  
               return allStates.split(/, +/g).map( function (state) {
                  return {
                     value: state.toLowerCase(),
                     display: state
                  };
               });
            }
            
            //filter function for search query
            function createFilterFor(query) {
               var lowercaseQuery = angular.lowercase(query);
               return function filterFn(state) {
                  return (state.value.indexOf(lowercaseQuery) === 0);
               };
            }
         }  
      </script>      
   </head>
   
   <body ng-app = "firstApplication" ng-cloak>
      <div ng-controller = "autoCompleteController as ctrl" layout = "column" ng-cloak>
         <md-content class = "md-padding">
            <form ng-submit = "$event.preventDefault()">
               <p><code>md-autocomplete</code> can be used to provide search results from
               local or remote data sources.</p>
               
               <md-autocomplete
                  ng-disabled = "ctrl.isDisabled"
                  md-no-cache = "ctrl.noCache"
                  md-selected-item = "ctrl.selectedItem"
                  md-search-text-change = "ctrl.searchTextChange(ctrl.searchText)"
                  md-search-text = "ctrl.searchText"
                  md-selected-item-change = "ctrl.selectedItemChange(item)"
                  md-items = "item in ctrl.querySearch(ctrl.searchText)"
                  md-item-text = "item.display"
                  md-min-length = "0"
                  placeholder = "US State?">
                  
                  <md-item-template>
                     <span md-highlight-text = "ctrl.searchText"
                        md-highlight-flags = "^i">{{item.display}}</span>
                  </md-item-template>
                  
                  <md-not-found>
                     No states matching "{{ctrl.searchText}}" were found.
                     <a ng-click = "ctrl.newState(ctrl.searchText)">Create a new one!</a>
                  </md-not-found>
               </md-autocomplete>
               <br/>
               
               <md-checkbox ng-model = "ctrl.simulateQuery">Show progress for results?
                  </md-checkbox>
               <md-checkbox ng-model = "ctrl.noCache">Disable caching?</md-checkbox>
               <md-checkbox ng-model = "ctrl.isDisabled">Disable?</md-checkbox>
               <p><code>md-autocomplete</code> caches results when performing a query.
               After first call, it uses the cached results to eliminate unnecessary
               server requests or lookup logic and it can be disabled.</p>
            </form>
         </md-content>
      </div>
   </body>
</html>

परिणाम

परिणाम सत्यापित करें।