首頁 > web前端 > js教程 > 詳細分析使用AngularJS編程中提交表單的方式_AngularJS

詳細分析使用AngularJS編程中提交表單的方式_AngularJS

WBOY
發布: 2016-05-16 15:53:54
原創
1032 人瀏覽過

在AngularJS出現之前,許多開發者就面對了表單提交這一問題。由於提交表單的方式繁雜而不同,很容易令人瘋掉……然而現在看來,依然會讓人瘋掉。

今天,我們會看看過去使用PHP方式提交的表單,現在如何將其轉換為使用Angular提交。使用Angular來處理表單,對我而言,是一個「啊哈」時刻(譯者:表示了解或發現某事物的喜悅)。即使它甚至沒有涉及多少Angular表層的東西,但是它卻幫助用戶看到表單提交之後的潛力,並且理解兩種資料綁定方式。

我們會使用jQuery平台來進行這個處理過程。所以要做的工作先是使用javascript。我們會提交表單,展示錯誤訊息,新增錯誤類,並且在javascript中顯示和隱藏訊息。


之後,我們會使用Angular。在使用之前,我們要做大部分所需的工作,我們之前所做的許多工作會非常容易。讓我們開始吧。

簡單的表單

我們會注意兩種提交表單的方式:

  •     舊方法:jQuery和PHP提交表單
  •     新方法:AngularJS與PHP提交表單

先看一下我們的表單,超簡單:

2015619102411460.jpg (800×400)

形式要求

  •     實作頁面無刷新表單處理
  •     輸入姓名與超級英雄別名
  •     若有錯誤,顯示錯誤提示
  •     若輸入錯誤,將輸入變成紅色
  •     若所有內容ok,顯示成功提示

文件結構

在我們的展示中,只需兩份文件

  •     index.html
  •     process.php

 
表單處理

讓我們新建一個PHP來處理表單。該頁面非常小並且使用POST方式提交資料。

處理表單:這對我們來說並不是那麼重要的。你可以使用其他你喜歡的語言來處理你的表單。
 

// process.php
 
<&#63;php
 
$errors   = array();  // array to hold validation errors
$data    = array();   // array to pass back data
 
// validate the variables ======================================================
 if (empty($_POST['name']))
  $errors['name'] = 'Name is required.';
 
 if (empty($_POST['superheroAlias']))
  $errors['superheroAlias'] = 'Superhero alias is required.';
 
// return a response ===========================================================
 
 // response if there are errors
 if ( ! empty($errors)) {
 
  // if there are items in our errors array, return those errors
  $data['success'] = false;
  $data['errors'] = $errors;
 } else {
 
  // if there are no errors, return a message
  $data['success'] = true;
  $data['message'] = 'Success!';
 }
 
 // return all our data to an AJAX call
 echo json_encode($data);

登入後複製
這是一個非常簡單的表單處理腳本。我們只檢查資料是否存在,如果存在,則不做任何處理和操做;如果不存在,則需要在$errors數組中添加一條資訊。

為了返回我們的資料進行AJAX調用,我們需要使用echo和json_encode。這就是我們PHP表單處理所有需要做的操作。使用普通的jQuery AJAX或Angular處理表單也是這樣的。
 展示表單

讓我們建立一個HTML來展示我們的表單

<!-- index.html -->
 
<!doctype html>
<html>
<head>
 <title>Angular Forms</title>
 
 <!-- LOAD BOOTSTRAP CSS -->
 <link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.2/css/bootstrap.min.css">
 
 <!-- LOAD JQUERY -->
  <!-- when building an angular app, you generally DO NOT want to use jquery -->
  <!-- we are breaking this rule here because jQuery's $.param will help us send data to our PHP script so that PHP can recognize it -->
  <!-- this is jQuery's only use. avoid it in Angular apps and if anyone has tips on how to send data to a PHP script w/o jQuery, please state it in the comments -->
  <script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
 
 <!-- PROCESS FORM WITH AJAX (OLD) -->
 <script>
  <!-- WE WILL PROCESS OUR FORM HERE -->
 </script>
</head>
<body>
<div class="container">
<div class="col-md-6 col-md-offset-3">
 
 <!-- PAGE TITLE -->
 <div class="page-header">
  <h1><span class="glyphicon glyphicon-tower"></span> Submitting Forms with Angular</h1>
 </div>
 
 <!-- SHOW ERROR/SUCCESS MESSAGES -->
 <div id="messages"></div>
 
 <!-- FORM -->
 <form>
  <!-- NAME -->
  <div id="name-group" class="form-group">
   <label>Name</label>
   <input type="text" name="name" class="form-control" placeholder="Bruce Wayne">
   <span class="help-block"></span>
  </div>
 
  <!-- SUPERHERO NAME -->
  <div id="superhero-group" class="form-group">
   <label>Superhero Alias</label>
   <input type="text" name="superheroAlias" class="form-control" placeholder="Caped Crusader">
   <span class="help-block"></span>
  </div>
 
  <!-- SUBMIT BUTTON -->
  <button type="submit" class="btn btn-success btn-lg btn-block">
   <span class="glyphicon glyphicon-flash"></span> Submit!
  </button>
 </form>
 
</div>
</div>
</body>
</html>

登入後複製

現在,我們有表單了。我們另外也使用了Bootstrap來讓表單看起來不是那麼醜。使用Bootstrap語法規則,每個input包含一個spot來展示我們文本的錯誤訊息。

2015619102451118.jpg (800×400)

使用jQuery提交表單

現在,讓我們來使用jQuery處理表單提交。我會將所有的程式碼加到空的

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板