Занятие 5.

Шаблоны

SIS.Angular.2018

Петров  Андрей

Домашняя работа №4

Что понравилось:

  1. Интересные и стильные реализации таймеров

  2. Многие справились с задачей

  3. Вынесение кода таймера в отдельные классы и компоненты

В чем были проблемы:

  1. Имена не всегда были понятны

  2. Не было имплементации интерфейса OnDestroy

Основная идея Angular

06.01.2010

Сейчас

Расширение HTML

План занятия

  • Data binding
  • Директивы
  • Pipes (пайпы)
  • Change Detection Cycle

Способы расширения HTML

Новый синтаксис

<p>
  Времени прошло с открытия страницы: {{secondsSinceOpen}} секунд
</p>
<img [src]="prima.photoSource" [alt]="prima.name">

Новые тэги и аттрибуты

<h1>Hello angular!</h1>
<app-prima></app-prima>

Data binding

Обмен данными между компонентом и DOM

String interpolation

@Component({
  selector: 'app-prima',
  templateUrl: './prima.component.html',
  styleUrls: ['./prima.component.css']
})
export class PrimaComponent {

  name: string;

  constructor() {
    this.name = 'Майя Плисецкая';
  }

}
<p>
  Имя: {{name}}
</p>

Вставляет значения как строки в DOM

Property binding

@Component({
  selector: 'app-prima',
  templateUrl: './prima.component.html',
  styleUrls: ['./prima.component.css']
})
export class PrimaComponent {

  prima: Prima;

  constructor() {
    this.prima = new Prima(
      'Майя Плисецкая',
      new Date(1925, 10, 20),
      'assets/img/pliseckaya.jpg'
    );
  }

}
<img [src]="prima.photoSource"
     [alt]="prima.name">

Записывает значение в свойство DOM-элемента

Event binding

@Component({
  selector: 'app-prima',
  templateUrl: './prima.component.html',
  styleUrls: ['./prima.component.css']
})
export class PrimaComponent implements OnInit {

  secondsSinceOpen: number = 0;

  ngOnInit() {
    setInterval(() => this.secondsSinceOpen++, 1000);
  }

  resetTimer() {
    this.secondsSinceOpen = 0;
  }
}
<button (click)="resetTimer()">Сбросить таймер</button>

Выполняет выражение при возникновении DOM-события

Two way data binding

@Component({
  selector: 'app-prima',
  templateUrl: './prima.component.html',
  styleUrls: ['./prima.component.css']
})
export class PrimaComponent {

  name: string;

  constructor() {
    this.name = 'Майя Плисецкая';
  }

}
<label>Введите имя</label>
<input [(ngModel)]="name">

ngModel находится в модуле FormsModule

Синхронизирует значение поля и свойство DOM-элемента

Banana in the box

Практика

Задача: сделать простой калькулятор с историей операций

Пример отображения выражения

11+15=26

Директивы

Компоненты

Новые тэги и атрибуты

Атрибутные

Структурные

Атрибутные директивы

Модифицируют поведение элементов

ngClass

<div [ngStyle]="{'color': person.country === 'RF' ? 'green' : 'red' }">
    {{person.name}}
</<div>

ngStyle

<div [ngClass]="{'rf-citizen': person.country === 'RF' }">
    {{person.name}}
</<div>

Структурные директивы

ngIf

<div *ngFor="let todo of todos">
  <div [title]="todo.description">{{todo.title}}</div>
</div>
<div>{{todo.title}}</div>
<button *ngIf="canDelete" (click)="delete()">Удалить</button>

ngFor

Меняют структуру DOM: добавляют, удаляют, копируют элементы

ngSwitch

<div [ngSwitch]="tab">
  <div *ngSwitchCase='skills'>Читаю, пишу</div>
  <div *ngSwitchCase='hobbies'>Ядерная физика</div>
</div>

Пайпы

Конвейер, трансформирующий значение

<div>{{donutDough | oven | glaze}}</div>

Тесто для пончика => печь => глазурь => пончик

Change Detection Cycle

Шаблон

Поменять имя

updateName() {
  this.name = 'Maiya';
}

Event binding

Имя: {{name}}

Change Detection

Полезные ссылки

  1. Введение в отображение данных
    https://angular.io/guide/displaying-data
     

  2. Синтаксис шаблонов и директивы
    https://angular.io/guide/template-syntax
     

  3. Пайпы
    https://angular.io/guide/pipes
     

  4. Поиск изменений в шаблонах
    https://blog.thoughtram.io/angular/2016/02/22/angular-2-change-detection-explained.html

Домашнее задание

  • Вынести списки с информацией о себе в поля с массивами, итерировать по ним с помощью ngFor

  • Добавить поле ввода нового увлечения/навыка, а также кнопку для добавления введенного значения в соответствующий список

  • * Сделать вкладки с помощью ngSwitch
  • * Добавить хранение отредактированных данных в localStorage браузера

Вопросы?

Angular templates

By walkingdev

Angular templates

  • 376