千家信息网

angular指令和管道怎么用

发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,本篇内容主要讲解"angular指令和管道怎么用",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"angular指令和管道怎么用"吧!指令 Directive
千家信息网最后更新 2025年02月23日angular指令和管道怎么用

本篇内容主要讲解"angular指令和管道怎么用",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"angular指令和管道怎么用"吧!

指令 Directive


指令是 Angular 提供的操作 DOM 的途径。指令分为属性指令结构指令

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

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

1、内置指令

1.1 *ngIf

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

没有更多数据
课程列表没有更多数据

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

  

1.2 [hidden]

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

课程列表
没有更多数据

1.3 *ngFor

遍历数据生成HTML结构

interface List {  id: number  name: string  age: number}list: List[] = [  { id: 1, name: "张三", age: 20 },  { id: 2, name: "李四", age: 30 }]
  • identify(index, item){  return item.id; }

    2、自定义指令

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

    Hello Angular
    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"  }}

    管道 Pipe


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

    1、内置管道

    • date 日期格式化

    • currency 货币格式化

    • uppercase 转大写

    • lowercase 转小写

    • json 格式化 json 数据

    {{ date | date: "yyyy-MM-dd" }}

    2、自定义管道

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

    {{'这是一个测试' | summary: 3}}
    // summary.pipe.tsimport { Pipe, PipeTransform } from '@angular/core';@Pipe({   name: 'summary' });export class SummaryPipe implements PipeTransform {    transform (value: string, limit?: number) {        if (!value) return null;        let actualLimit = (limit) ? limit : 50;        return value.substr(0, actualLimit) + '...';    }}
    // app.module.tsimport { SummaryPipe } from './summary.pipe'@NgModule({    declarations: [      SummaryPipe    ] });

    到此,相信大家对"angular指令和管道怎么用"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    0