>  기사  >  웹 프론트엔드  >  Angular의 지시문, 파이프 및 서비스에 대한 심층 분석

Angular의 지시문, 파이프 및 서비스에 대한 심층 분석

青灯夜游
青灯夜游앞으로
2021-09-18 10:58:132143검색

Angular의 명령어, 파이프 및 서비스는 무엇인가요? 다음 문서에서는 Angular의 지침, 파이프라인 및 서비스를 안내합니다. 도움이 되기를 바랍니다.

Angular의 지시문, 파이프 및 서비스에 대한 심층 분석

1. 지시문 DirectiveDirective

指令是 Angular 提供的操作 DOM 的途径。指令分为属性指令和结构指令。【相关教程推荐:《angular教程》】

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

结构指令:增加、删除 DOM 节点以修改布局,使用*作为指令前缀

1.1 内置指令

1.1.1 *ngIf

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

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

1.1.2  [hidden]

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

<div [hidden]="data.length === 0">没有更多数据</div>

1.1.3   *ngFor

遍历数据生成HTML结构

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

list: List[] = [
  { id: 1, name: "张三", age: 20 },
  { id: 2, name: "李四", age: 30 }
]
<!--  
    i: 索引
    isEven: 是否为偶数行
    isOdd: 是否为奇数行
    isFirst: 是否是第一项
    isLast: 是否是最后一项
-->
<li
    *ngFor="
      let item of list; 
      let i = index;
      let isEven = even;
      let isOdd = odd;
      let isFirst = first;
      let isLast = last;
    "
></li>
<li *ngFor="let item of list; trackBy: identify"></li>
identify(index, item){
  return item.id; 
}

1.2  自定义指令

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

<div [appHover]="{ bgColor: &#39;skyblue&#39; }">Hello Angular</div>
  • 创建自定义指令

$ ng g d appHover
# 全称 ng generate directive
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"
  }
}

2.   管道 Pipe

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

2.1  内置管道

  • date 日期格式化

  • currency 货币格式化

  • uppercase 转大写

  • lowercase 转小写

  • json 格式化json 数据

<p>{{ date | date: "yyyy-MM-dd" }}</p>

2.2  自定义管道

需求:指定字符串不能超过规定的长度

// 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 : 10;
        return value.substr(0, actualLimit) + &#39;...&#39;;
    }
}
// app.module.ts
import { SummaryPipe } from &#39;./summary.pipe&#39;
@NgModule({
    declarations: [SummaryPipe] 
});

3.  服务 Service

Directive는 DOM을 동작시키기 위해 Angular에서 제공하는 방식입니다. 명령어는 속성 명령어와 구조 명령어로 나누어진다. [관련 튜토리얼 추천: "

angular tutorial"]속성 지침: 기존 요소의 모양이나 동작을 수정하고 []를 사용하여 래핑합니다.

구조적 지침: DOM 노드를 추가 및 삭제하여 레이아웃을 수정하고 *를 지침 접두어로 사용하세요

1.1 내장 지침
  • 1.1 .1 *ngIf
  • 조건에 따라 DOM 노드를 렌더링하거나 DOM 노드를 제거
  • $ ng g s services/TestService --skip-tests
    import { Injectable } from &#39;@angular/core&#39;;
    
    @Injectable({
      providedIn: &#39;root&#39;
    })
    export class TestService { }
  • 1.1 .2 [숨김]

조건에 따라 DOM 노드를 표시하거나 DOM 노드를 숨깁니다(display)
export class AppComponent {
  constructor (private testService: TestService) {}
}


1.1.3 *ngFor

데이터를 탐색하여 HTML 구조 생성
import { Injectable } from &#39;@angular/core&#39;;

@Injectable({
  providedIn: &#39;root&#39;
})

export class CarListService {
}
import { Injectable } from &#39;@angular/core&#39;;
import { CarModule } from &#39;./car.module&#39;;

@Injectable({
  providedIn: CarModule,
})

export class CarListService {
}
import { CarListService } from &#39;./car-list.service&#39;;

@NgModule({
  providers: [CarListService],
})
export class CarModule {
}
import { Component } from '@angular/core';
import { CarListService } from '../car-list.service.ts'

@Component({
  selector:    'app-car-list',
  templateUrl: './car-list.component.html',
  providers:  [ CarListService ]
})

1.2 맞춤 지침

🎜🎜🎜요구 사항: 요소의 기본 배경색을 설정합니다. 마우스가 들어올 때의 배경색, 마우스가 나갈 때의 배경색 배경색🎜rrreee🎜🎜🎜맞춤 명령어 만들기🎜🎜🎜rrreeerrreee
🎜🎜2.파이프 파이프🎜🎜 🎜파이프의 역할은 구성 요소 템플릿 데이터의 형식을 지정하는 것입니다. 🎜🎜🎜🎜2.1 내장 파이프라인🎜🎜🎜🎜🎜🎜날짜 날짜 형식🎜🎜🎜🎜통화 통화 형식🎜🎜🎜🎜대문자 대문자로 변환 🎜🎜🎜🎜소문자 소문자로 변환 🎜🎜🎜🎜json json 데이터 형식 🎜🎜🎜rrreee🎜🎜🎜2.2 사용자 정의 Pipeline🎜🎜🎜🎜요구 사항: 지정된 문자열은 지정된 길이를 초과할 수 없습니다🎜rrreeerrreee🎜🎜3. 서비스Service🎜🎜🎜🎜🎜3.1 서비스 생성🎜🎜🎜rrreeerrreeerrreee🎜3.2 서비스 범위🎜 🎜 사용 서비스를 사용하면 서비스 범위에 따라 모듈과 구성 요소 간에 데이터를 쉽게 공유할 수 있습니다. 🎜🎜🎜🎜루트 인젝터에 서비스를 등록하고 모든 모듈은 동일한 서비스 인스턴스 객체를 사용합니다🎜rrreee🎜🎜🎜모듈 수준에서 서비스를 등록하고 모듈의 모든 구성 요소는 동일한 서비스 인스턴스 객체를 사용합니다🎜rrreeerrreee🎜🎜🎜In 컴포넌트 레벨 등록 서비스에서 이 컴포넌트와 해당 하위 컴포넌트는 동일한 서비스 인스턴스 객체를 사용합니다🎜rrreee🎜🎜🎜🎜원본 주소: https://juejin.cn/post/7008357218210807838🎜🎜🎜저자: Qianyi_0810🎜🎜🎜더 보기 프로그래밍 관련 지식은 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜

위 내용은 Angular의 지시문, 파이프 및 서비스에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 掘金--浅忆_0810에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제