2014-10-30 19 views
7

Sto provando a includere una selezione ui in una direttiva personalizzata. (https://github.com/angular-ui/ui-select)AngularJS Avvolgimento di una selezione ui in una direttiva personalizzata

this.adminv2.directive('eventSelect', function() { 
    return { 
     restrict: 'E', 
     replace: true, 
     scope: { 
     ngModel: '=', 
     placeholder: '=' 
     }, 
     controller: function($scope, $http) { 
     return $scope.refreshEvents = function(searchTerm) { 
      return $http.get('/events/autocomplete', { 
      params: { 
       term: searchTerm 
      } 
      }).then(function(response) { 
      return $scope.events = response.data; 
      }); 
     }; 
     }, 
     template: "<div>{{ngModel}}\n <ui-select ng-model=\"ngModel\"\n    theme=\"bootstrap\"\n    ng-disabled=\"disabled\"\n    reset-search-input=\"false\">\n <ui-select-match placeholder=\"Enter an event\">{{$select.selected.name}}</ui-select-match>\n <ui-select-choices repeat=\"event in events track by $index\"\n    refresh=\"refreshEvents($select.search)\"\n    refresh-delay=\"0\">\n  <span ng-bind-html=\"event.name | highlight: $select.search\"></span>\n  <i class=\"icon-uniF111 fg type-{{raceType}} pull-right\" ng-repeat='raceType in event.racetypes'></i>\n  <br>\n  {{event.dates}} <i class='pull-right'>{{event.location}}</i>\n </ui-select-choices>\n </ui-select>\n</div>" 
    }; 
    }); 

Le selezionare funzioni correttamente, ma il legame con ng-modello non funziona. Non riesco a impostare il modello o leggerlo. Io non capisco perché funziona quando uso un semplice modello di come

<div><input ng-model="ngModel"></div> 

C'è qualcosa di speciale da fare perché mi avvolgo una direttiva nella direttiva?

risposta

12

sono riuscito a fare il lavoro vincolante impostando il ng-modello il modello come

ng-model="$parent.ngModel" 
+3

Grazie mille, mi era stato battendo la testa contro questo problema e la risposta ha reso il lavoro anche per me. Sapresti perché questo funziona? – forgivenson

+0

Grazie, grazie, grazie! – Wlada

Problemi correlati