亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解Angular 4 表單快速入門

發布時間:2020-10-26 02:39:24 來源:腳本之家 閱讀:110 作者:semlinker 欄目:web開發

基礎知識

Angular CLI 基本使用

安裝 Angular CLI (可選)

npm install -g @angular/cli

創建新的項目

ng new PROJECT-NAME

啟動本地服務器

cd PROJECT-NAME
ng serve

Angular Forms 簡介

Angular 4 中有兩種表單:

  1. Template Driven Forms - 模板驅動式表單 (類似于 AngularJS 1.x 中的表單 )
  2. Reactive Forms - 響應式表單

本文主要介紹 Template Driven Forms (模板驅動式表單) 的基礎知識,相關的知識點會以問答的形式進行介紹。

第一節 - 創建最簡單的輸入框

如何實現雙向綁定?

在 Angular 表單中,我們通過 ngModel 指令來實現雙向綁定。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
  <input type="text" [(ngModel)]="username">
  {{username}}
 `,
})
export class AppComponent {
 username = 'semlinker';
}

第二節 - 添加簡單的驗證功能

如何為表單控件添加驗證功能?

目前 Angular 支持的內建 validators 如下:

  1. required - 設置表單控件值是非空的
  2. email - 設置表單控件值的格式是 email
  3. minlength - 設置表單控件值的最小長度
  4. maxlength - 設置表單控件值的最大長度
  5. pattern - 設置表單控件的值需匹配 pattern 對應的模式

接下來我們來添加最簡單的 必填 校驗。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
  <input 
   type="text" 
   required
   [(ngModel)]="username">
  {{username}}
 `,
})
export class AppComponent {
 username = 'semlinker';
}

如何判斷表單控件是否通過驗證?

在 Angular 中,我們可以通過 #userName="ngModel" 方式獲取 ngModel 對象,然后通過 userName.valid 判斷表單控件是否通過驗證。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
  <input 
   type="text" 
   required
   [(ngModel)]="username"
   #userName="ngModel">
  {{userName.valid}}
 `,
})
export class AppComponent {
 username = 'semlinker';
}

第三節 - 顯示驗證失敗的錯誤信息

如何顯示驗證失敗的錯誤信息?

在 Angular 中,我們可以通過 #userName="ngModel" 方式獲取 ngModel 對象,然后通過該對象的 errors 屬性,來獲取對應驗證規則 (如 required, minlength 等) 的驗證狀態。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
  <input 
   type="text" 
   required
   minlength="3"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
 `,
})
export class AppComponent {
 username = 'semlinker';
}

第四節 - 創建表單

如何使用表單?

在 Angular 中,我們可以使用熟悉的 <form> 標簽來創建表單。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <form>
  <input 
   type="text" 
   required
   minlength="3"
   name="username"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
  <button type="submit">提交</button>
 </form>
 `,
})
export class AppComponent {
 username = 'semlinker';
}

需要注意的是,在使用 <form> 標簽后,我們的 username 輸入框,必須添加 name 屬性。

如何獲取表單提交的值?

在 Angular 中,我們可以通過 #loginForm="ngForm" 方式獲取 ngForm 對象,然后通過 loginForm.value 來獲取表單的值。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
  <input 
   type="text" 
   required
   minlength="3"
   name="username"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
  <button type="submit">提交</button>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 username = 'semlinker';

 onSubmit(value) {
  console.dir(value);
 }
}

第五節 - ngModelGroup簡介

ngModelGroup 有什么作用?

ngModelGroup 指令是 Angular 表單中提供的另一特殊指令,可以對表單輸入內容進行分組,方便我們在語義上區分不同性質的輸入。例如聯系人的信息包括姓名及住址,現在需對姓名和住址進行精細化信息收集,姓名可精細化成姓和名字,地址可精細化成城市、區、街等。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
  <fieldset ngModelGroup="user">
  <input 
   type="text" 
   required
   minlength="3"
   name="username"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
  <input type="password" ngModel name="password">
  </fieldset>
  <button type="submit">提交</button>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 username = 'semlinker';

 onSubmit(value) {
  console.dir(value);
 }
}

以上代碼成功運行后,{{loginForm.value | json}} 的輸出結果:

{ "user": { "username": "semlinker", "password": "123" } }

第六節 - 表單添加驗證狀態樣式

如何為表單添加驗證狀態樣式信息?

在 Angular 表單中,若驗證通過則會在表單控件上添加 ng-valid 類,若驗證失敗則會在表單控件上添加 ng-invalid 類。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 styles: [`
  input.ng-invalid {
    border: 3px solid red;
  }
  input.ng-valid {
    border: 3px solid green;
  }
 `
 ],
 template: `
 <form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
  <fieldset ngModelGroup="user">
  <input 
   type="text" 
   required
   minlength="3"
   name="username"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
  <input type="password" required ngModel name="password">
  </fieldset>
  <button type="submit">提交</button>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 username = 'semlinker';

 onSubmit(value) {
  console.dir(value);
 }
}

第七節 - 表單控件的狀態

表單控件除了 valid 狀態外,還包含哪些狀態?

在 Angular 中表單控件有以下 6 種狀態,我們可以通過 #userName="ngModel" 方式獲取 ngModel 對象,進而獲取控件的狀態信息。具體狀態如下:

  1. valid - 表單控件有效
  2. invalid - 表單控件無效
  3. pristine - 表單控件值未改變
  4. dirty - 表單控件值已改變
  5. touched - 表單控件已被訪問過
  6. untouched - 表單控件未被訪問過
import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 styles: [`
  input.ng-invalid {
    border: 3px solid red;
  }
  input.ng-valid {
    border: 3px solid green;
  }
 `
 ],
 template: `
 <form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
  <fieldset ngModelGroup="user">
  <input 
   type="text" 
   required
   minlength="3"
   name="username"
   [(ngModel)]="username"
   #userName="ngModel">
  <hr>
  <p>Name控件的valid狀態:{{userName.valid}} - 表示控件有效</p>
  <p>Name控件的invalid狀態:{{userName.invalid}} - 表示控件無效</p>
  <p>Name控件的pristine狀態:{{userName.pristine}} - 表示控件值未改變</p>
  <p>Name控件的dirty狀態:{{userName.dirty}} - 表示控件值已改變</p>
  <p>Name控件的touched狀態:{{userName.touched}} - 表示控件已被訪問過</p>
  <p>Name控件的untouched狀態:{{userName.untouched}} - 表示控件未被訪問過</p>
  <div *ngIf="userName.errors?.required">請您輸入用戶名</div>
  <div *ngIf="userName.errors?.minlength">
   用戶名的長度必須大于 {{userName.errors?.minlength.requiredLength}},當前的長度為
    {{userName.errors?.minlength.actualLength}}
  </div>
  <input type="password" required ngModel name="password">
  </fieldset>
  <button type="submit">提交</button>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 username = 'semlinker';

 onSubmit(value) {
  console.dir(value);
 }
}

第八節 - 使用單選控件

如何添加單選控件?

在 Angular 中,我們通過 <input name="***" type="radio"> 方式添加單選控件。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <form #loginForm="ngForm">
  Angular版本:
  <div *ngFor="let version of versions;">
    <input 
     [attr.id]="version"
      name="version"
      ngModel
      required
      [value]="version"
      type="radio">
     <label [attr.for]="version">{{version}}</label>
   </div>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 versions = ['1.x', '2.x', '3.x'];
}

第九節 - 使用多選控件

如何添加多選控件?

在 Angular 中,我們通過 <select name="***"> 方式添加多選控件。

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 <form #loginForm="ngForm">
  Angular版本:
  <select name="version" [ngModel]="versions[0]">
     <option
      *ngFor="let version of versions;"
      [value]="version">
       {{version}}
    </option>
   </select>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 versions = ['1.x', '2.x', '3.x'];
}

如何添加必填驗證?

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 styles: [`
  select.ng-invalid + label:after {
   content: '<-- 請選擇版本!'
  }
 `
 ],
 template: `
 <form #loginForm="ngForm">
  Angular版本:
  <div>
   <select name="version" [ngModel]="version" required>
    <option
    *ngFor="let version of versions;"
     [value]="version">
     {{version}}
    </option>
   </select>
   <label></label>
  </div>
  <hr>
  {{loginForm.value | json}}
 </form>
 `,
})
export class AppComponent {
 versions = ['','1.x', '2.x', '3.x'];
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

易门县| 肇源县| 讷河市| 乐陵市| 清丰县| 嘉祥县| 临泉县| 平定县| 禄劝| 福泉市| 南川市| 利川市| 新兴县| 肇东市| 小金县| 通榆县| 溧阳市| 理塘县| 鄂伦春自治旗| 龙江县| 五莲县| 古丈县| 景泰县| 泰兴市| 内乡县| 济源市| 资源县| 西平县| 确山县| 韶山市| 尉犁县| 司法| 喀喇沁旗| 蓝山县| 龙泉市| 辽源市| 曲阳县| 达尔| 广东省| 海伦市| 达孜县|