6

鉴于以下指令

directive('myDirective', function() {
    return {
        restrict: 'A',
        scope: {},
        replace: false,
        template: '<input ng-focus="onFocus()" type="text" />',
        link: function(scope, element, attr) {
            scope.onFocus = function() {
                console.log('got focus');
            };
        }
    };
});

我已经测试了焦点观察器在浏览器中的工作,但我希望能够在单元测试中触发它。这是我尝试过的,但它不起作用。

var element = angular.element('<div my-directive></div>');
$compile(element)($scope);
$scope.$digest();
element.find('input')[0].focus();

我可以看到我通过 find 调用正确地进入了输入框,并且我希望该代码能够触发输入框上的焦点事件,但没有发生任何事情。我在这里想念什么?

4

1 回答 1

18

当尝试在 angular 元素上触发事件时,应该使用triggerHandler()函数,它只是真正的 jqLit​​e 函数而不是 angulars,然后将事件作为字符串参数传递,如下所示。

element.find('input').triggerHandler('focus');

要在角度元素上执行任何其他功能,请阅读此处的文档,它向您显示了角度元素可用的函数列表

于 2014-01-28T16:28:46.970 回答