Угловой 6 - Формы

В этой главе мы увидим, как формы используются в Angular 6. Мы обсудим два способа работы с формами - формы, управляемые шаблонами и формы, управляемые моделями.

Форма на основе шаблона

В форме, управляемой шаблоном, большая часть работы выполняется в шаблоне; а с формой, управляемой моделью, большая часть работы выполняется в классе компонентов.

Давайте теперь рассмотрим работу над формой, управляемой шаблоном. Мы создадим простую форму входа и добавим идентификатор электронной почты, пароль и отправим кнопку в форму. Для начала нам нужно импортировать в FormsModule из@angular/core что делается в app.module.ts следующим образом -

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule} from '@angular/router';
import { HttpModule } from '@angular/http';
import { FormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
import { MyserviceService } from './myservice.service';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
@NgModule({
   declarations: [
      SqrtPipe,
      AppComponent,
      NewCmpComponent,
      ChangeTextDirective
   ],
   imports: [
      BrowserModule,
      HttpModule,
      FormsModule,
      RouterModule.forRoot([
         {path: 'new-cmp',component: NewCmpComponent}
      ])
   ],
   providers: [MyserviceService],
   bootstrap: [AppComponent]
})
export class AppModule { }

Так что в app.module.ts, мы импортировали FormsModule, и он добавлен в массив импорта, как показано в выделенном коде.

Давайте теперь создадим нашу форму в app.component.html файл.

<form #userlogin = "ngForm" (ngSubmit) = "onClickSubmit(userlogin.value)" >
   <input type = "text" name = "emailid" placeholder = "emailid" ngModel>
   <br/>
   <input type = "password" name = "passwd" placeholder = "passwd" ngModel>
   <br/>
   <input type = "submit" value = "submit">
</form>

Мы создали простую форму с тегами ввода, содержащими идентификатор электронной почты, пароль и кнопку отправки. Мы присвоили ему тип, имя и заполнитель.

В формах, управляемых шаблонами, нам нужно создать элементы управления формы модели, добавив ngModel директива и nameатрибут. Таким образом, где бы мы ни хотели, чтобы Angular получал доступ к нашим данным из форм, добавьте к этому тегу ngModel, как показано выше. Теперь, если нам нужно прочитать emailid и passwd, нам нужно добавить к ним ngModel.

Если вы видите, мы также добавили ngForm в #userlogin. ВngFormдирективу необходимо добавить в созданный нами шаблон формы. Мы также добавили функциюonClickSubmit и назначил userlogin.value к нему.

Давайте теперь создадим функцию в app.component.ts и получить значения, введенные в форму.

import { Component } from '@angular/core';
import { MyserviceService } from './myservice.service';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 6 Project!';
   todaydate;
   componentproperty;
   constructor(private myservice: MyserviceService) { }
   ngOnInit() {
      this.todaydate = this.myservice.showTodayDate();
   }
   onClickSubmit(data) {
      alert("Entered Email id : " + data.emailid);
   }
}

В приведенном выше app.component.tsфайла, мы определили функцию onClickSubmit. Когда вы нажимаете кнопку отправки формы, управление переходит к указанной выше функции.

Так отображается браузер -

Форма выглядит так, как показано ниже. Давайте введем в него данные, а в функции отправки уже введен идентификатор электронной почты.

Идентификатор электронной почты отображается внизу, как показано на скриншоте выше.

Модель управляемая форма

В форме, управляемой моделью, нам нужно импортировать ReactiveFormsModule из @ angular / forms и использовать его в массиве import.

Есть изменение, которое происходит в app.module.ts.

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule} from '@angular/router';
import { HttpModule } from '@angular/http';
import { ReactiveFormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
import { MyserviceService } from './myservice.service';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
@NgModule({
   declarations: [
      SqrtPipe,
      AppComponent,
      NewCmpComponent,
      ChangeTextDirective
   ],
   imports: [
      BrowserModule,
      HttpModule,
      ReactiveFormsModule,
      RouterModule.forRoot([
         {
            path: 'new-cmp',
            component: NewCmpComponent
         }
      ])
   ],
   providers: [MyserviceService],
   bootstrap: [AppComponent]
})
export class AppModule { }

В app.component.ts, нам нужно импортировать несколько модулей для формы, управляемой моделью. Например,import { FormGroup, FormControl } from '@angular/forms'.

import { Component } from '@angular/core';
import { MyserviceService } from './myservice.service';
import { FormGroup, FormControl } from '@angular/forms';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 6 Project!';
   todaydate;
   componentproperty;
   emailid;
   formdata;
   constructor(private myservice: MyserviceService) { }
   ngOnInit() {
      this.todaydate = this.myservice.showTodayDate();
      this.formdata = new FormGroup({
         emailid: new FormControl("[email protected]"),
         passwd: new FormControl("abcd1234")
      });
   }
   onClickSubmit(data) {this.emailid = data.emailid;}
}

Переменная formdata инициализируется в начале класса, и то же самое инициализируется с помощью FormGroup, как показано выше. Переменные emailid и passwd инициализируются значениями по умолчанию, которые будут отображаться в форме. Вы можете оставить его пустым, если захотите.

Вот как значения будут отображаться в пользовательском интерфейсе формы.

Мы использовали formdata для инициализации значений формы; нам нужно использовать то же самое в пользовательском интерфейсе формыapp.component.html.

<div>
   <form [formGroup] = "formdata" (ngSubmit) = "onClickSubmit(formdata.value)" >
      <input type = "text" class = "fortextbox" name = "emailid" placeholder = "emailid" 
         formControlName="emailid">
      <br/>
      
      <input type = "password" class = "fortextbox" name="passwd" 
         placeholder = "passwd" formControlName = "passwd">
      <br/>
      
      <input type = "submit" class = "forsubmit" value = "Log In">
   </form>
</div>
<p>
   Email entered is : {{emailid}}
</p>

В файле .html мы использовали formGroup в квадратных скобках для формы; например, [formGroup] = "formdata". При отправке функция вызываетсяonClickSubmit для которого formdata.value передается.

Входной тег formControlNameиспользуется. Ему дается значение, которое мы использовали вapp.component.ts файл.

При нажатии кнопки «Отправить» управление передается функции onClickSubmit, который определен в app.component.ts файл.

При нажатии кнопки «Войти» значение будет отображаться, как показано на скриншоте выше.

Проверка формы

Давайте теперь обсудим проверку формы с использованием формы, управляемой моделями. Вы можете использовать встроенную проверку формы или также использовать подход индивидуальной проверки. Мы будем использовать оба подхода в форме. Мы продолжим с того же примера, который мы создали в одном из наших предыдущих разделов. В Angular 4 нам нужно импортировать валидаторы из@angular/forms как показано ниже -

import { FormGroup, FormControl, Validators} from '@angular/forms'

Angular имеет встроенные валидаторы, такие как mandatory field, minlength, maxlength, а также pattern. Доступ к ним можно получить с помощью модуля Validators.

Вы можете просто добавить валидаторы или массив валидаторов, необходимых для того, чтобы сообщить Angular, является ли определенное поле обязательным.

Давайте теперь попробуем то же самое с одним из текстовых полей ввода, то есть с идентификатором электронной почты. Для идентификатора электронной почты мы добавили следующие параметры проверки -

  • Required
  • Сопоставление с образцом

Вот как код проходит проверку в app.component.ts.

import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators} from '@angular/forms';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 6 Project!';
   todaydate;
   componentproperty;
   emailid;
   formdata;
   ngOnInit() {
      this.formdata = new FormGroup({
         emailid: new FormControl("", Validators.compose([
            Validators.required,
            Validators.pattern("[^ @]*@[^ @]*")
         ])),
         passwd: new FormControl("")
      });
   }
   onClickSubmit(data) {this.emailid = data.emailid;}
}

В Validators.compose, вы можете добавить список вещей, которые вы хотите проверить, в поле ввода. Прямо сейчас мы добавилиrequired и pattern matching параметры, чтобы принимать только действующий адрес электронной почты.

в app.component.html, кнопка отправки неактивна, если какой-либо из входных данных формы недействителен. Это делается следующим образом -

<div>
   <form [formGroup] = "formdata" (ngSubmit) = "onClickSubmit(formdata.value)" >
      <input type = "text" class = "fortextbox" name = "emailid" placeholder = "emailid" 
         formControlName = "emailid">
      <br/>
      <input type = "password" class = "fortextbox" name = "passwd" 
         placeholder = "passwd" formControlName = "passwd">
      <br/>
      <input type = "submit" [disabled] = "!formdata.valid" class = "forsubmit" 
         value = "Log In">
   </form>
</div>
<p>
   Email entered is : {{emailid}}
</p>

Для кнопки отправки мы добавили отключение в квадратную скобку, которой присвоено значение - !formdata.valid. Таким образом, если formdata.valid недействителен, кнопка останется отключенной, и пользователь не сможет ее отправить.

Давайте посмотрим, как это работает в браузере -

В приведенном выше случае введенный идентификатор электронной почты недействителен, поэтому кнопка входа в систему отключена. Давайте теперь попробуем ввести действительный идентификатор электронной почты и увидим разницу.

Теперь введенный идентификатор электронной почты действителен. Таким образом, мы видим, что кнопка входа в систему включена, и пользователь сможет ее отправить. При этом введенный идентификатор электронной почты отображается внизу.

Давайте теперь попробуем настраиваемую проверку с той же формой. Для пользовательской проверки мы можем определить нашу собственную пользовательскую функцию и добавить в нее необходимые детали. Теперь мы рассмотрим пример того же.

import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators} from '@angular/forms';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css']
})
export class AppComponent {
   title = 'Angular 6 Project!';
   todaydate;
   componentproperty;
   emailid;
   formdata;
   ngOnInit() {
      this.formdata = new FormGroup({
         emailid: new FormControl("", Validators.compose([
            Validators.required,
            Validators.pattern("[^ @]*@[^ @]*")
         ])),
         passwd: new FormControl("", this.passwordvalidation)
      });
   }
   passwordvalidation(formcontrol) {
      if (formcontrol.value.length < 5) {
         return {"passwd" : true};
      }
   }
   onClickSubmit(data) {this.emailid = data.emailid;}
}

В приведенном выше примере мы создали функцию password validation и то же самое используется в предыдущем разделе в formcontrol - passwd: new FormControl("", this.passwordvalidation).

В созданной нами функции мы проверим, соответствует ли длина введенных символов. Если символов меньше пяти, он вернется с паролем true, как показано выше -return {"passwd" : true};. Если символов больше пяти, это будет считаться действительным, и вход в систему будет включен.

Давайте теперь посмотрим, как это отображается в браузере -

Мы ввели всего три символа в пароль, и логин отключен. Для включения логина нам понадобится более пяти символов. Давайте теперь введем допустимую длину символов и проверим.

Вход в систему включен, поскольку действительны как идентификатор электронной почты, так и пароль. Электронная почта отображается внизу при входе в систему.