微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AngularJS UniformJS选择控件不更新

我正在使用AngularJS和UniformJS构建应用程序.我想在视图上有一个重置按钮,可以将我的选择重置为认值.如果我使用uniform.js,它就无法正常工作.

你可以在这里检查它:

http://plnkr.co/edit/QYZRzlRf1qqAYgi8VbO6?p=preview

如果连续单击重置按钮,则不会执行任何操作.
如果删除属性,因此不再使用uniform.js,则一切都正常.

谢谢

更新:

需要使用超时.

app.controller('MainCtrl',function($scope,$timeout) {
  $scope.reset = function() {
    $scope.test = "";
    $timeout(jQuery.uniform.update,0);
  };
});

解决方法

找到了.为了完整起见,我在这里复制我的评论

看起来Uniform非常hacky.它覆盖了实际的select元素,而是显示span. Angular正在发挥作用.实际的选择元素的值正在变化,但Uniform显示的范围不会改变.

所以你需要通过jQuery.uniform.update告诉Uniform你的值已经改变了. Uniform从实际元素中读取值以放置在span中,而angular直到摘要循环之后才更新实际元素,因此在调用update之前需要稍等一点:

app.controller('MainCtrl',0);
  };
});

或者,您可以将它放在您的指令中:

app.directive('applyUniform',function($timeout){
  return {
    restrict:'A',require: 'ngModel',link: function(scope,element,attr,ngModel) {
      element.uniform({useID: false});
      scope.$watch(function() {return ngModel.$modelValue},function() {
        $timeout(jQuery.uniform.update,0);
      } );
    }
  };
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐