我喜欢Bootstrap-Select并且我目前正在通过另一个用户发出的指令的帮助来使用它,joaoneto/angular-bootstrap-select并且它按预期工作,除非我尝试用包装器填充我的<select>元素,$http或者在我的情况下是dataService包装器。我似乎遇到了一些时间问题,数据是在selectpicker显示/刷新之后出现的,然后我最终得到了一个空的 Bootstrap-Select 列表。尽管使用 Firebug,我确实看到了 now hidden 中的值列表<select>。如果我然后进入控制台并手动执行$('.selectpicker').selectpicker('refresh')它然后工作。
我通过打补丁并在.selectpicker('refresh')内部添加一个来临时工作,$timeout但你知道这并不理想,因为我们jQuery直接在 ngController 中使用......哎呀!
因此,我相信该指令可能缺少观察者,或者至少缺少一些触发ngModel更改或更新的东西。
html示例代码:
<div class="col-sm-5">
<select name="language" class="form-control show-tick"
ng-model="vm.profile.language"
selectpicker data-live-search="true"
ng-options="language.value as language.name for language in vm.languages">
</select>
<!-- also tried with an ng-repeat, which has the same effect -->
</div>
然后在我的 Angular 控制器中:
// get list of languages from DB
dataService
.getLanguages()
.then(function(data) {
vm.languages = data;
// need a timeout patch to properly refresh the Bootstrap-Select selectpicker
// not so good to use this inside an ngController but it's the only working way I have found
$timeout(function() {
$('.selectpicker, select[selectpicker]').selectpicker('refresh');
}, 1);
});
这是 (joaoneto) 在GitHub 上为 Angular-Bootstrap-Select制定的指令
function selectpickerDirective($parse, $timeout) {
return {
restrict: 'A',
priority: 1000,
link: function (scope, element, attrs) {
function refresh(newVal) {
scope.$applyAsync(function () {
if (attrs.ngOptions && /track by/.test(attrs.ngOptions)) element.val(newVal);
element.selectpicker('refresh');
});
}
attrs.$observe('spTheme', function (val) {
$timeout(function () {
element.data('selectpicker').$button.removeClass(function (i, c) {
return (c.match(/(^|\s)?btn-\S+/g) || []).join(' ');
});
element.selectpicker('setStyle', val);
});
});
$timeout(function () {
element.selectpicker($parse(attrs.selectpicker)());
element.selectpicker('refresh');
});
if (attrs.ngModel) {
scope.$watch(attrs.ngModel, refresh, true);
}
if (attrs.ngDisabled) {
scope.$watch(attrs.ngDisabled, refresh, true);
}
scope.$on('$destroy', function () {
$timeout(function () {
element.selectpicker('destroy');
});
});
}
};
}