在这个特殊的情况下,我有什么选项,使这些输入调用函数时,我按下Enter?

Html:

<form>
    <input type="text" ng-model="name" <!-- Press ENTER and call myFunc --> />
    <br />
    <input type="text" ng-model="email" <!-- Press ENTER and call myFunc --> />
</form>
// Controller //
.controller('mycontroller', ['$scope',function($scope) {
    $scope.name = '';
    $scope.email = '';
    // Function to be called when pressing ENTER
    $scope.myFunc = function() {
       alert('Submitted');
    };
}])

当前回答

另一个方法是使用ng-keypress,

<input type="text" ng-model="data" ng-keypress="($event.charCode==13)? myfunc() : return"> 

用AngularJS - jsfiddle按Enter键提交输入

其他回答

Angular提供了开箱即用的支持。你在表单元素上尝试过ngSubmit吗?

<form ng-submit="myFunc()" ng-controller="mycontroller">
   <input type="text" ng-model="name" />
    <br />
    <input type="text" ng-model="email" />
</form>

编辑:根据关于提交按钮的评论,请参阅通过按enter不提交按钮提交表单,其中给出了解决方案:

<input type="submit" style="position: absolute; left: -9999px; width: 1px; height: 1px;"/>

如果您不喜欢隐藏的提交按钮解决方案,则需要将控制器函数绑定到Enter keypress或keyup事件。这通常需要一个自定义指令,但AngularUI库已经设置了一个很好的按键解决方案。参见http://angular-ui.github.com/

添加angularUI库后,你的代码会像这样:

<form ui-keypress="{13:'myFunc($event)'}">
  ... input fields ...
</form>

或者您可以将回车键绑定到每个单独的字段。

另外,请参阅创建简单keypres指令的SO问题: 如何在AngularJS中检测onKeyUp ?

编辑(2014-08-28):在写这个答案的时候,ng-keypress/ng-keyup/ng-keydown还不存在于AngularJS中。在下面的评论中@darlan-alves有一个很好的解决方案:

<输入ng -keyup = " $事件。==地理==根据美国人口普查,这个县的总面积为,其中土地和(0.991平方公里)水。/>

使用CSS类而不是重复内联样式会稍微整洁一些。

CSS

input[type=submit] {
    position: absolute;
    left: -9999px;
}

HTML

<form ng-submit="myFunc()">
    <input type="text" ng-model="name" />
    <br />
    <input type="text" ng-model="email" />
    <input type="submit" />
</form>

另一个方法是使用ng-keypress,

<input type="text" ng-model="data" ng-keypress="($event.charCode==13)? myfunc() : return"> 

用AngularJS - jsfiddle按Enter键提交输入

我把重点放在表中输入的行下面

<input ng-keydown="$event.keyCode == 13 && onPressEnter($event)" id="input_0" type="text" >

    $scope.onPressEnter = function (event) {
    let inputId = event.target.id;
    let splited = inputId.split('_');
    let newInputId = 'input' + '_' + ((+splited[1]) + 1);
    if (document.getElementById(newInputId))
        document.getElementById(newInputId).focus();
   // else submit form
}

如果只有一个输入,则可以使用form标记。

<form ng-submit="myFunc()" ...>

如果你有多个输入,或者不想使用form标签,或者想将输入键功能附加到一个特定的字段,你可以将它内联到一个特定的输入,如下所示:

<input ng-keyup="$event.keyCode == 13 && myFunc()" ...>