我有以下创建input
元素的 AngularJS 指令。输入具有ng-change
运行doIt()
功能的属性。在我的指令的单元测试中,我想检查doIt
用户更改输入时是否调用了函数。但是测试没有通过。虽然它在手动测试时在浏览器中工作。
指示:
...
template: "<input ng-model='myModel' ng-change='doIt()' type='text'>"
测试:
el.find('input').trigger('change') // Dos not trigger ng-change
现场演示(ng-change):http ://plnkr.co/edit/0yaUP6IQk7EIneRmphbW?p=preview
现在,如果我手动绑定change
事件而不是使用ng-change
属性,则测试通过。
template: "<input ng-model='myModel' type='text'>",
link: function(scope, element, attrs) {
element.bind('change', function(event) {
scope.doIt();
});
}
现场演示(手动绑定):http ://plnkr.co/edit/dizuRaTFn4Ay1t41jL1K?p=preview
有没有办法使用ng-change
并使其可测试?谢谢你。