角度材料md-autocomplete排序和要搜索的最小长度范围

时间:2016-03-08 18:54:18

标签: angularjs angular-material md-autocomplete

因为我从我的服务器获取数据..我不会从搜索的第一个字母开始点击服务器...我的wana修复了一些最小长度后md-autocompleate操作应该通过正确的排序和最少10条记录作为选择......

目前我在查看页面

中有这个
<div ng-controller="ContactChipDemoCtrl as ctrl" layout="column" class="chipsdemoContactChips">

        <md-content class="md-padding autocomplete" layout="column">
        <md-contact-chips
        ng-model="ctrl.contacts"
        md-contacts="ctrl.querySearch($query)"
        md-contact-name="name"
        md-contact-image="image"
        md-contact-email="email"
        md-require-match=""
        filter-selected="ctrl.filterSelected"
        placeholder="To">
      </md-contact-chips><!--md-min-length="3" i wonder y this for-->
      <div ng-repeat="c in ctrl.contacts">{{c.name}}</div>
    </md-content>
  </div>

这在我的控制器搜索查询中是电子邮件ID

keynotesApp.controller('ContactChipDemoCtrl', DemoCtrl);

function DemoCtrl ($timeout, $q, $http) {
  var self = this;

  self.querySearch = querySearch;
  self.contacts = [];
  self.filterSelected = true;

    /**
     * Search for contacts.
     */
     function querySearch (query) {
      var result;
      if(query) {
        result = loadAndParseContacts().then(function(data) {
          console.log(data)
         return data.filter(createFilterFor(query))
       })
      } else {
        result = []
      }
      return result
    }

    /**
     * Create filter function for a query string
     */
     function createFilterFor(query) {
      var lowercaseQuery = angular.lowercase(query);

      return function filterFn(contact) {
        return (contact._lowername.indexOf(lowercaseQuery) != -1);;
      };

    }
    function parse (data) {
      return data.data.map(function (c, index) {
        var contact = {
          name: c.email,
                      };
          contact._lowername = contact.name.toLowerCase();
          return contact;
        })      
    }
    function loadAndParseContacts() {
      var maxRecs = 10;
      var fields = ('email _id name avatar organization jobTitle');
      var sort = ({email:'ascending'});//this is not working i wonder why
      return $http({
        method: 'GET',
        url: '/users/find',
        params: {fields: fields, maxRecs: maxRecs, sort: sort }
      })
      .then(parse)
    }
  }


md-autocompleate工作正常... bt排序,最小长度,最大记录是我想要的所有......帮助提前感谢

0 个答案:

没有答案