admin管理员组文章数量:1345059
From Angular's documentation it follows that ngSubmit is a preferred way of submitting a form. All pending operations are immediately finished and $submitted
flag is set as well. Whereas listening to ngClick
event does not have the same effect.
Now I need to submit a form with hotkeys having all the goodies of ngSubmit
approach. Hence I need some way to trigger standard submit workflow.
I tried submit()
on DOM form and it worked, but angular's form object attached to scope contains no references to DOM form, thus I need to access it through jqLite:
var frm = angular.element('#frmId');
frm.submit();
I didn't like this solution for accessing DOM in controller code so I created a directive:
function wuSubmit() {
return {
require: 'form',
restrict: 'A',
link: function(scope, element, attributes) {
var scope = element.scope();
if (attributes.name && scope[attributes.name]) {
scope[attributes.name].$submit = function() {
element[0].submit();
};
}
}
};
}
which extends form object with $submit
method.
Both variants do not work for yet unknown reason. form.submit()
tries to send data, default action is not prevented.
Update 1
It turns out that Angular listens to click events of elements having type="input"
.
Eventually I decided to trigger click event for that element:
wuSubmit.$inject = ['$timeout'];
function wuSubmit($timeout) {
return {
require: 'form',
restrict: 'A',
link: function (scope, element, attributes) {
var submitElement = element.find('[type="submit"]').first();
if (attributes.name && scope[attributes.name]) {
scope[attributes.name].$submit = submit;
}
function submit() {
$timeout(function() {
submitElement.trigger('click');
});
}
}
};
}
Is there any out of the box solution for this functionality?
From Angular's documentation it follows that ngSubmit is a preferred way of submitting a form. All pending operations are immediately finished and $submitted
flag is set as well. Whereas listening to ngClick
event does not have the same effect.
Now I need to submit a form with hotkeys having all the goodies of ngSubmit
approach. Hence I need some way to trigger standard submit workflow.
I tried submit()
on DOM form and it worked, but angular's form object attached to scope contains no references to DOM form, thus I need to access it through jqLite:
var frm = angular.element('#frmId');
frm.submit();
I didn't like this solution for accessing DOM in controller code so I created a directive:
function wuSubmit() {
return {
require: 'form',
restrict: 'A',
link: function(scope, element, attributes) {
var scope = element.scope();
if (attributes.name && scope[attributes.name]) {
scope[attributes.name].$submit = function() {
element[0].submit();
};
}
}
};
}
which extends form object with $submit
method.
Both variants do not work for yet unknown reason. form.submit()
tries to send data, default action is not prevented.
Update 1
It turns out that Angular listens to click events of elements having type="input"
.
Eventually I decided to trigger click event for that element:
wuSubmit.$inject = ['$timeout'];
function wuSubmit($timeout) {
return {
require: 'form',
restrict: 'A',
link: function (scope, element, attributes) {
var submitElement = element.find('[type="submit"]').first();
if (attributes.name && scope[attributes.name]) {
scope[attributes.name].$submit = submit;
}
function submit() {
$timeout(function() {
submitElement.trigger('click');
});
}
}
};
}
Is there any out of the box solution for this functionality?
Share Improve this question edited Aug 18, 2018 at 14:21 georgeawg 49k13 gold badges77 silver badges98 bronze badges asked Dec 29, 2014 at 13:53 Pavel VoroninPavel Voronin 14k9 gold badges76 silver badges149 bronze badges 1- How are you binding normal form submission in your form in HTML? – Shashank Agrawal Commented Dec 29, 2014 at 13:55
3 Answers
Reset to default 4Just use event .triggerHandler('submit') on form element.
myApp.directive("extSubmit", ['$timeout',function($timeout){
return {
link: function($scope, $el, $attr) {
$scope.$on('makeSubmit', function(event, data){
if(data.formName === $attr.name) {
$timeout(function() {
$el.triggerHandler('submit'); //<<< This is Important
//equivalent with native event
//$el[0].dispatchEvent(new Event('submit'))
}, 0, false);
}
})
}
};
}]);
Look at http://jsfiddle/84bodm5p/
app.directive("form", function(){
return {
require: 'form',
restrict: 'E',
link: function(scope, elem, attrs, form) {
form.doSubmit = function() {
form.$setSubmitted();
return scope.$eval(attrs.ngSubmit);
};
}
};
});
Html:
<form name="myForm" ng-submit="$ctrl.submit()" novalidate>
Then call in controller
$scope.myForm.doSubmit();
You can modify your directive code a bit like:
function wuSubmit() {
return {
require: 'form',
restrict: 'A',
link: function(scope, element, attributes) {
var scope = element.scope();
if (attributes.name && scope[attributes.name]) {
scope[attributes.name].$submit = function() {
// Parse the handler of submit & execute that.
var fn = $parse(attr.ngSubmit);
$scope.$apply(function() {
fn($scope, {$event: e});
});
};
}
}
};
}
Here you don't have to add wu-submit
everywhere. ng-submit
will work.
Hope this helps!
本文标签: javascriptHow to trigger form submit programmatically in AngularJSStack Overflow
版权声明:本文标题:javascript - How to trigger form submit programmatically in AngularJS? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743802433a2541565.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论