如何确定ng-options何时完成更新DOM?

时间:2013-03-12 18:40:16

标签: javascript mvvm angularjs angularjs-directive

我正在尝试使用我的应用程序中的指令实现jQuery multiselect插件。这里是选择元素:

<select multiple 
        ng-model="data.partyIds" 
        ng-options="party.id as party.name for party in parties" 
        xs-multiselect="parties">
</select>

模型parties模型通过$ http加载。 multiselect插件解析option内的select元素,并生成很好的多选。

有没有办法检测select元素何时填充了选项,以便我可以告诉多选插件更新其数据?

这是我的指示:

machineXs.directive("xsMultiselect", function() {
    return {
        restrict: "A",
        require: '?ngModel',
        link: function(scope, element, attrs, ngModel) {
            element.multiselect().multiselectfilter();
            scope.$watch(scope[attrs["xsMultiselect"]], function() {
                // I tried watching but it doesn't help
                element.multiselect('refresh');
                element.multiselectfilter("updateCache");
            });
        }
    }
});

1 个答案:

答案 0 :(得分:5)

如评论中所述,请使用

scope.$watch(attrs.xsMultiselect, ...)

我不确定手表何时触发vs ngOptions更新DOM时。如果您发现手表过早触发,可以尝试使用$evalAsync()或$ timeout()。 $ evalAsync将在稍后执行,但在DOM渲染之前执行。在DOM渲染之后,$ timeout()将在稍后执行。

scope.$watch(attrs.xsMultiselect, function() {
   scope.$evalAsync(function() {
      element.multiselect('refresh');
      element.multiselectfilter("updateCache");
   });
});

或者,在DOM渲染之后:

scope.$watch(attrs.xsMultiselect, function() {
   $timeout(function() {
      element.multiselect('refresh');
      element.multiselectfilter("updateCache");
   });
});