处理表单在我们的旧表单中,我们使用jQuery提交表单,像这样$('form').submit()。现在我们使用Angular称作ng-submit的特性。要想完成这个,我们需要添加一个控制器函数来处理表单,然后告诉我们form使用这个控制器函数: 05 | <!-- PROCESS FORM WITH AJAX (NEW) --> |
09 | var formApp = angular.module( 'formApp' , []); |
12 | function formController($scope, $http) { |
19 | $scope.processForm = function () { |
28 | <form ng-submit= "processForm()" > |
现在我们的form知道提交时使用控制器函数了。既然已经到位了,然我们用$http来处理表单吧。 处理表单的语法看起来跟原始方式很像。好处是我们不需要手动抓取表单数据,或者注入,隐藏,添加类显示错误或成功信息。 06 | $scope.processForm = function () { |
10 | data : $.param($scope.formData), |
11 | headers : { 'Content-Type' : 'application/x-www-form-urlencoded' } |
13 | .success( function (data) { |
18 | $scope.errorName = data.errors.name; |
19 | $scope.errorSuperhero = data.errors.superheroAlias; |
22 | $scope.message = data.message; |
这就是我们的表单!没有添加或移除类。我们需要每次提交表单时都清楚错误。我们只需绑定变量和需要用到的视图。这非常棒,因为处理器用来处理数据,而视图用来显示数据.
jQuery POST vs Angular POST
有时能看到用POST方式提交在服务器中看不到数据,这是因为jQuery和Angular的序列化和发送数据的方式不同。这归结于你所使用的服务器语言和它理解Angular提交的数据的能力。 上面的代码是应用于PHP服务器的,jQuery对于$.param函数则是必需的。虽然实现上文中提到的内容有非常多不使用jQuery的方法,但在本实例中,使用jQuery的唯一原因就是,它更简单。 下面简洁的语法将会基于你服务器端语言来工作。更多关于AngularJS AJAX调用的信息,欢迎阅读这篇非常棒的文章:Make AngularJS $http Service Behave Like jQuery AJAX
简洁语法
这个例子是以字符串的方式发送数据,并且发送你的头信息。如果你不需要这些,并且希望Angular 的$http POST尽可能的简洁,我们可以使用简写方法: 2 | $http.post( 'process.php' , $scope.formData) |
3 | .success( function (data) { |
绝对更简洁更容易记住方法。 $http 内部控制器: 理想的,你可以将$http请求从controller移除到 service.这只是为了演示目的,我们将会尽快在service上进行讨论.
在视图中显示错误和信息我们将使用指令ng-show和ng-class来处理我们的视图,Angular双方括号允许我们将变量放置在我们需要的地方。 ng-show: 根据变量值是否存在来显示或隐藏元素. 文档 ng-class: 根据变量值是否存在(或一些其他表达式)来添加或移除类. 文档 06 | < div id = "messages" ng-show = "message" >{{ message }}</ div > |
11 | < div id = "name-group" class = "form-group" ng-class = "{ 'has-error' : errorName }" > |
13 | < input type = "text" name = "name" class = "form-control" placeholder = "Bruce Wayne" > |
14 | < span class = "help-block" ng-show = "errorName" >{{ errorName }}</ span > |
18 | < div id = "superhero-group" class = "form-group" ng-class = "{ 'has-error' : errorSuperhero }" > |
19 | < label >Superhero Alias</ label > |
20 | < input type = "text" name = "superheroAlias" class = "form-control" placeholder = "Caped Crusader" > |
21 | < span class = "help-block" ng-show = "errorSuperhero" >{{ errorSuperhero }}</ span > |
我们的表单完成了!通过强大的Angular,我们可以将这些愚蠢的显示/隐藏的js代码逻辑从视图中移走 了。现在我们的js文件只用来处理数据,并且视图可以做它自己的事情了。
我们的类和错误/成功等提示信息将在可获取时显示而不可获取时隐藏。当我们无须再像使用老的javascript那样担心是否已经考虑全面,这变得更加容易。你也无须再担心是否记得隐藏每处form提交时的那些错误信息。 Angular表单验证 获取更多表单验证的信息,请研读我们另一文章:AngularJS Form Validation。 结束语现在我们已把美观的表单全部转变为Angular的了。我们共同学习了许多概念,希望你与它们接触更多,它们也将更易用。 回顾: 创建一个Angular module 创建一个Angular controller 双向数据绑定 ng-model绑定inputs ng-click提交表单 使用双向数据绑定展示表单错误 展示一个基于是否变量存在的div 添加一个基于是否变量存在的类
这些Angular技术将在更庞大的应用中使用,你可以用它们创建许多好东西。祝Angular之途愉快,敬请期待更多深入的文章。同时,你也可以通过深入了解其指南,服务和厂商等来继续学习Angular。
查看代码 : https://github.com/scotch-io/submitting-forms-angular |