Maison > interface Web > js tutoriel > le corps du texte

L'apprentissage angulaire parle d'instructions et de pipelines

青灯夜游
Libérer: 2022-05-17 11:01:57
avant
1607 Les gens l'ont consulté

Cet article vous amènera à comprendre la Directive et le Pipe dans angular, et présentera brièvement les points de connaissances pertinents : instructions intégrées et instructions personnalisées, tuyaux intégrés et tuyaux personnalisés. J'espère qu'il sera utile à tout le monde. !

L'apprentissage angulaire parle d'instructions et de pipelines

Directive Directive


La directive est le moyen fourni par Angular pour manipuler le DOM . Les instructions sont divisées en Instructions d'attribut et Instructions structurelles. 操作 DOM 的途径。指令分为属性指令结构指令

  • 属性指令:修改现有元素的外观或行为,使用 [] 包裹。

  • 结构指令:增加、删除 DOM 节点以修改布局,使用*作为指令前缀。【相关教程推荐:《angular教程》】

1、内置指令

1.1 *ngIf

根据条件渲染 DOM 节点或移除 DOM 节点。

<div *ngIf="data.length == 0">没有更多数据</div>
Copier après la connexion
<div *ngIf="data.length > 0; then dataList else noData"></div>
<ng-template #dataList>课程列表</ng-template>
<ng-template #noData>没有更多数据</ng-template>
Copier après la connexion

ng-template 是用来定义模板的,当使用 ng-template 定义好一个模板之后,可以用 ng-container templateOutlet 指令来进行使用。

<ng-template #loading>
 <button (click)="login()">login</button>
 <button (click)="sigup()">sigup</button>
</ng-template>
<ng-container *ngTemplateOutlet="loading">
</ng-container>
Copier après la connexion

1.2 [hidden]

根据条件显示 DOM 节点或隐藏 DOM 节点 (display)。

<div [hidden]="data.length == 0">课程列表</div>
<div [hidden]="data.length > 0">没有更多数据</div>
Copier après la connexion

1.3 *ngFor

遍历数据生成HTML结构

interface List {
  id: number
  name: string
  age: number
}

list: List[] = [
  { id: 1, name: "张三", age: 20 },
  { id: 2, name: "李四", age: 30 }
]
Copier après la connexion
<li
    *ngFor="
      let item of list;
      let i = index;
      let isEven = even;
      let isOdd = odd;
      let isFirst = first;
      let isLast = last;
    "
  >
  </li>
Copier après la connexion
<li *ngFor="let item of list; trackBy: identify"></li>
Copier après la connexion
identify(index, item){
  return item.id; 
}
Copier après la connexion

2、自定义指令

需求:为元素设置默认背景颜色,鼠标移入时的背景颜色以及移出时的背景颜色。

<div [appHover]="{ bgColor: &#39;skyblue&#39; }">Hello Angular</div>
Copier après la connexion
import { AfterViewInit, Directive, ElementRef, HostListener, Input } from "@angular/core"

// 接收参的数类型
interface Options {
  bgColor?: string
}

@Directive({
  selector: "[appHover]"
})
export class HoverDirective implements AfterViewInit {
  // 接收参数
  @Input("appHover") appHover: Options = {}
  // 要操作的 DOM 节点
  element: HTMLElement
	// 获取要操作的 DOM 节点
  constructor(private elementRef: ElementRef) {
    this.element = this.elementRef.nativeElement
  }
	// 组件模板初始完成后设置元素的背景颜色
  ngAfterViewInit() {
    this.element.style.backgroundColor = this.appHover.bgColor || "skyblue"
  }
	// 为元素添加鼠标移入事件
  @HostListener("mouseenter") enter() {
    this.element.style.backgroundColor = "pink"
  }
	// 为元素添加鼠标移出事件
  @HostListener("mouseleave") leave() {
    this.element.style.backgroundColor = "skyblue"
  }
}
Copier après la connexion

管道 Pipe


管道的作用是格式化组件模板数据

    Directive Attribut : Pour modifier l'apparence ou le comportement d'un élément existant, utilisez [] pour l'envelopper. Instructions structurelles : ajoutez et supprimez des nœuds DOM pour modifier la disposition, utilisez * comme préfixe d'instruction. [Recommandations de tutoriel associées : "

    Tutoriel angulaire
      "]
    • 1. Instructions intégrées

    • 1.1 *ngIf
    • Rendu basé sur les conditions < /code> Nœud DOM ou <code>supprimer Nœud DOM.

      {{ date | date: "yyyy-MM-dd" }}
      Copier après la connexion
      <!-- 这是一... -->
      {{&#39;这是一个测试&#39; | summary: 3}}
      Copier après la connexion
    • ng-template est utilisé pour définir des modèles. Après avoir utilisé ng-template pour définir un modèle, vous pouvez utiliser ng-container Utiliser. avec la directive templateOutlet.
    • // summary.pipe.ts
      import { Pipe, PipeTransform } from &#39;@angular/core&#39;;
      
      @Pipe({
         name: &#39;summary&#39; 
      });
      export class SummaryPipe implements PipeTransform {
          transform (value: string, limit?: number) {
              if (!value) return null;
              let actualLimit = (limit) ? limit : 50;
              return value.substr(0, actualLimit) + &#39;...&#39;;
          }
      }
      Copier après la connexion

      1.2 [caché]

    Afficher les nœuds DOM ou masquer les nœuds DOM (affichage) en fonction des conditions.

    // app.module.ts
    import { SummaryPipe } from &#39;./summary.pipe&#39;
    @NgModule({
        declarations: [
          SummaryPipe
        ] 
    });
    Copier après la connexion
    1.3 *ngFor

    Traversez les données pour générer la structure HTML

    rrreeerrreeerrreeerrreee

    2. Instructions personnalisées

    🎜🎜🎜Exigences : Définissez la couleur d'arrière-plan par défaut pour l'élément, l'arrière-plan. lorsque la souris est déplacée en couleur et la couleur d'arrière-plan lorsqu'elle est déplacée. 🎜rrreeerrreee🎜🎜Pipe Pipe🎜🎜🎜🎜🎜La fonction de pipe est de formater les données du modèle de composant. 🎜🎜🎜🎜🎜1. Pipeline intégré🎜🎜🎜🎜🎜🎜formatage de la date🎜🎜🎜🎜formatage de la devise🎜🎜🎜🎜minuscule en minuscule 🎜🎜🎜🎜données json au format json 🎜 🎜🎜rrreee🎜🎜🎜2. Pipeline personnalisé🎜🎜🎜🎜Exigence : La chaîne spécifiée ne peut pas dépasser la longueur spécifiée🎜rrreeerrreeerrreee🎜Pour plus de connaissances sur la programmation, veuillez visiter : 🎜Vidéo de programmation🎜 ! ! 🎜

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:csdn.net
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal