It is very easy to achieve this in angular js .We can check with one example. Suppose you have one text box inside the form and want to submit on enter key here is the way.
 
<form name="name" class="form" ng-submit="submitform()">
 <input type="text" ng-model="model.term"/>
 
 <button type="submit" class="btn">
  Submit
 </button>
</form>
What we have done is that just defined our function in ng-submit. It will work perfectly but there are some situations we have to deal with multiple text box and have to submit on enter .In that case you can define simple directive and you can add your function on ng-enter .
Lets check with another example .
 
<input type="text" ng-enter="submifunction1();" ng-model="model.term1"/>
<input type="text" ng-enter="submifunction2();" ng-model="model.term2"/>
<input type="text" ng-enter="submifunction3();" ng-model="model.term3"/>
 
Directive
 
angular.module('yourmodule').directive('ngEnter', function () {
    return function (scope, element, attrs) {
        element.bind("keydown keypress", function (event) {
            if(event.which === 13) {
                scope.$apply(function (){
                    scope.$eval(attrs.ngEnter);
                });
 
                event.preventDefault();
            }
        });
    };
});
 
Related Posts
2. Rating Stars using angular js Directive concept
3. Communication between factory file and controller in Angular js
4. Communicate with controllers in angular js
5.Client side pagination using angular js
 

 
ng-keypress with $event.keyCode == 13
ReplyDeleteHey Prashobh,
ReplyDeleteThis solution works perfect.
But there is one problem.
I have a form, and inside this form I have many input fields. I just want to give enter submit to only one text field. When I used this directive to just one text field and tried to submit with another text field then also it works. How to get rid of this?
Thanks in advance.
Hi,
ReplyDeleteIt worked for me.
Thanks for the directive.
Regards,
Shashikiran
Just what I needed, thanks.
ReplyDeleteFinal thoughts: Very cute and effectively made.
ReplyDeleteIt worked for me too.
ReplyDeleteThanks for this code!
Hello there, You've done an excellent job. I will certainly digg it and in my view suggest to my friends.
ReplyDeleteI'm confident they will be benefited from this website.