AngularJS输入事件触发器

时间:2014-01-04 14:58:47

标签: angularjs javascript-events

我在网上搜索,如何在angularJS中实现jquery ui autocomplete。我找到了一个非常好的样品,它正在工作。这里Sourcecode

HTML

<div ng-app='MyModule'>
    <div ng-controller='DefaultCtrl'>
        <input auto-complete ui-items="names" ng-model="selected">
        selected = {{selected}}
    </div>
</div>  

JS

function DefaultCtrl($scope) {
    $scope.names = ["john", "bill", "charlie", "robert", "alban", "oscar", "marie", "celine", "brad", "drew", "rebecca", "michel", "francis", "jean", "paul", "pierre", "nicolas", "alfred", "gerard", "louis", "albert", "edouard", "benoit", "guillaume", "nicolas", "joseph"];
}

angular.module('MyModule', []).directive('autoComplete', function($timeout) {
    return function(scope, iElement, iAttrs) {
            iElement.autocomplete({
                source: scope[iAttrs.uiItems],
                select: function() {
                    $timeout(function() {
                      iElement.trigger('input');
                    }, 0);
                }
            });
    };
});

我真正感到困惑的是,关于select事件的触发器输入事件。

select: function() {
                    $timeout(function() {
                      iElement.trigger('input');
                    }, 0);
                }

什么是事件的输入,我从来没有听说过。我在互联网上搜索输入事件,但找不到有用的东西。

1 个答案:

答案 0 :(得分:1)

考虑它的好方法是这样的:它是一个键盘事件,过滤掉所有对输入的文本值没有影响的键,并在从先前输入值列表中选择完成时触发(感谢@szeryf提示!)。 有关详细信息,请参阅stackoverflow中的answer