Как избежать дубликатов в выборе нескольких угловых интерфейсов
У меня есть несколько виджетов UI-Select, и мне нужно обновить выбор, нажав на кнопку обновления.
<ui-select multiple ng-model="multipleDemo.selectedPeople" theme="select2" ng-disabled="disabled" style="width: 800px;">
<ui-select-match placeholder="Select person...">{{$item.name}} <{{$item.email}}></ui-select-match>
<ui-select-choices repeat="person in people | propsFilter: {name: $select.search, age: $select.search}">
<div ng-bind-html="person.name | highlight: $select.search"></div>
{{person.email}}
</ui-select-choices>
</ui-select>
Если я использую массив строк для переменных людей, он работает нормально. Но когда я использую массив объектов, дубликаты появляются в выборе. Вот фрагмент http://plnkr.co/edit/Jbhv1stbXEdNnt3of5aW?p=preview Как я могу избежать дублирования с объектами? Помогите, пожалуйста.
1 ответ
Решение
Решение, которое я нашел здесь https://github.com/angular-ui/ui-select/issues/580. Вы можете фильтровать данные, которые вы получаете от вашего API.
$scope.people = response.data.data.filter(function (i) {
return $multipleDemo.selectedPeople.map(function (e) { return e.id; }).indexOf(i.id) < 0;
}