返回顶部
首页 > 资讯 > 精选 >Angular中如何自定义创建指令
  • 887
分享到

Angular中如何自定义创建指令

2023-06-14 22:06:07 887人浏览 独家记忆
摘要

小编给大家分享一下angular中如何自定义创建指令,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!指令介绍在 Angular 中有三种类型的指令:组件,有模板的指

小编给大家分享一下angular中如何自定义创建指令,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

指令介绍

在 Angular 中有三种类型的指令:

  • 组件,有模板的指令,组件是继承于指令的,只是扩展类与 UI 相关的属性。

  • 属性型指令,改变 DOM 元素、组件或其他指令的行为和外观的指令。如,NgStyle、NGClass。

  • 结构型指令,通过添加或移除 DOM 元素改变 DOM 布局的指令。如,NgIf、NgFor。

然而,在实际的开发中,根据业务的需要,我们经常会拓展 Angular 组件的指令来方便业务的开发。下面让我们来看看如何创建自己的指令。

创建属性型指令

在 Angular 中,属性型指令的创建至少需要一个带有 @Directive 装饰器的控制器类。这个装饰器指定了一个选择器名称,用于标识与指令相关联的属性名称。控制器类实现了指令的功能行为。

接下来,我们创建一个简单的指令,实现鼠标在元素上悬停时,改变起背景颜色;鼠标移开时,背景颜色消失;鼠标点击时,字体变大;鼠标松开时,字体恢复原样的功能。

指令实现

创建 background-exed.directive.ts 文件,实现如下代码:

import { Directive, HostListener, ElementRef, Renderer2, HostBinding } from '@angular/core';@Directive({  selector: '[appBackgroundExe]'})export class BackgroundExeDirective {  @Input('appBackgroundExe')  highLightColor: string;  constructor(private elementRef: ElementRef, private renderer: Renderer2) {    // 这种写法比较丑陋    // this.elementRef.nativeElement.style.background = 'yellow';    // 推荐这种写法, Renderer    this.renderer.setStyle(this.elementRef.nativeElement, 'background', 'yellow');  }  @HostBinding('class.pressed')  isPressed: boolean;  @HostListener('mouseenter')  onMouseEnter(): void {   this.highLight(this.highLightColor);  }  @HostListener('mouseleave')  onMouseLeave(): void {    this.highLight(null);  }  @HostListener('mousedown')  onMouseDown(): void {    this.isPressed = true;  }  @HostListener('mouseup')  onMouseUp(): void {    this.isPressed = false;  }  private highLight(color: string): void {    // this.elementRef.nativeElement.style.background = color;    this.renderer.setStyle(this.elementRef.nativeElement, 'background', color);  }}

其中,selector: '[appBackgroundExe]' 是指令关联的属性名称,以便 Angular 在编译时,能从模板中找到与此指令关联的 html 代码。

构造函数中,注入了 ElementRefRenderer2 模块的实例。通过 ElementRef 我们可以引用指令标识的 DOM 元素,并对其进行相关的操作;并且可以利用 Renderer2 提供的 api 对元素进行相关的渲染操作。

@HostListener@HostBinding 是属性装饰器。@HostListener 是用来为宿主元素添加事件监听;而指令标记的元素,就是宿主元素。@HostBinding 是用来动态设置宿主元素的属性值。

设置字体样式

  • appliation.component.less

.pressed {  font-size: 30px;}

在模板中使用指令

  • application.component.html

<div class="panel panel-primary">  <div [appBackgroundExe]="'red'">鼠标移进,元素变成红色。鼠标移出,元素红色消失</div></div>

创建结构型指令

结构型指令的创建与属性型指令创建大同小异。

指令实现

import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';@Directive({    selector: '[appIf]'})export class IfDirective {    constructor(        private templateRef: TemplateRef<any>,        private viewContainerRef: ViewContainerRef    ) { }    @Input('ifCreat')     set condition(condition: boolean) {       if (condition) {         this.viewContainerRef.createEmbeddedView(this.templateRef);       } else {         this.viewContainerRef.clear();       }    }}

其中,TemplateRef 表示内嵌的 template 模板元素,通过它可以创建内嵌视图。ViewContainerRef 表示一个视图容器,可以添加一个或多个视图,通过它可以创建和管理基于 TemplateRef 实例的内嵌视图或组件视图。

在模板中使用指令

  • application.component.html

<div class="panel panel-primary">  <div *ifCreate="'true'">hello</div></div>

以上是“Angular中如何自定义创建指令”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Angular中如何自定义创建指令

本文链接: https://lsjlt.com/news/275408.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Angular中如何自定义创建指令
    小编给大家分享一下Angular中如何自定义创建指令,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!指令介绍在 Angular 中有三种类型的指令:组件,有模板的指...
    99+
    2023-06-14
  • Angular中如何自定义结构型指令和属性型指令
    今天小编给大家分享一下Angular中如何自定义结构型指令和属性型指令的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、自定...
    99+
    2023-07-05
  • Angular中怎么以Tooltip自定义指令
    本文小编为大家详细介绍“Angular中怎么以Tooltip自定义指令”,内容详细,步骤清晰,细节处理妥当,希望这篇“Angular中怎么以Tooltip自定义指令”文章能帮助大家解决疑惑,下面跟着小编的思...
    99+
    2024-04-02
  • 如何在Prometheus中创建自定义指标
    要在Prometheus中创建自定义指标,您需要遵循以下步骤: 创建一个用于暴露指标的应用程序或服务。您可以使用Promethe...
    99+
    2024-03-04
    Prometheus
  • angular中自定义指令的示例分析
    这篇文章将为大家详细讲解有关angular中自定义指令的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。自定义属性的四种类别分为: 元素E,属性A,注释M,类C ,...
    99+
    2024-04-02
  • Vue中如何自定义指令
    这篇文章主要介绍Vue中如何自定义指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Vue中除了内置指令,也允许注册自定义的指令。自定义指令提供一种将数据的变化映射为DOM的行为例如:当我们想用一个函数表示焦点Vue...
    99+
    2023-06-04
  • 如何在Prometheus系统中创建自定义指标
    要在Prometheus系统中创建自定义指标,您需要执行以下步骤: 创建一个新的指标定义文件,通常使用PromQL语言编写。您可...
    99+
    2024-03-04
    Prometheus
  • Angular自定义指令Tooltip的方法实例
    目录目录结构编写 tooltip 组件编写 tooltip 指令页面上调用总结Yeah,关注我的读者应该知道,上一篇文章了解 Angular 开发的内容,我们已经概览了 Angula...
    99+
    2024-04-02
  • Angular.js如何自定义指令
    这篇文章主要介绍了Angular.js如何自定义指令,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体代码如下所示:<!DOCTYPE...
    99+
    2024-04-02
  • Vue中如何使用自定义指令
    今天就跟大家聊聊有关Vue中如何使用自定义指令,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.自定义指令的语法Vue自定义指令语法如下:Vue.d...
    99+
    2024-04-02
  • PyQt 如何创建自定义QWidget
    目录开发环境主要文件:main.pyapp_main_window.pyTips多控件可以存在list中QApplication与QWidget注意widget持有外部对象引用的问题...
    99+
    2024-04-02
  • 浅析Angular中的自定义结构型/属性型指令
    Angular指令分为三种,组件(带模板指令)、结构型指令(改变宿主文档结构)、属性型指令(改变宿主行为),下面主要介绍自定义结构型指令和自定义属性型指令。一、自定义结构型指令一个元素上只能放一个结构型指令,结构型指令的书写形式为*指令名,...
    99+
    2023-05-14
    Angular
  • vue中的自定义指令如何使用
    这篇文章主要介绍“vue中的自定义指令如何使用”,在日常操作中,相信很多人在vue中的自定义指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中的自定义指令如何使用”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-29
  • vue如何使用自定义指令
    这篇文章将为大家详细讲解有关vue如何使用自定义指令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 使用自定义指令的逻辑与使用事件修饰符的逻辑...
    99+
    2024-04-02
  • vue如何自定义加载指令
    本文小编为大家详细介绍“vue如何自定义加载指令”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue如何自定义加载指令”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言用过element-ui的都应该知道,里面...
    99+
    2023-07-02
  • Angular中如何实现自定义管道
    这篇文章给大家分享的是有关Angular中如何实现自定义管道的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、管道的作用方便我们在模板中对我们的数据进行格式化处理。二、内置的常用...
    99+
    2024-04-02
  • C#如何创建自定义特性
    目录概述实现方式概述 特性(Attribute)是用于在运行时传递程序中各种元素(比如类、方法、结构、枚举、组件等)的行为信息的声明性标签。您可以通过使用特性向程序添加声明性信息。...
    99+
    2024-04-02
  • html如何创建自定义列表
    这篇文章主要介绍了html如何创建自定义列表,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。定义列表自定义列表不仅仅是一列项目,而是项目及其注...
    99+
    2024-04-02
  • 如何创建 JavaScript 自定义事件
    目录怎么创建自定义事件事件定制冒泡 bubbles可取消 cancelable组合 composed给事件传递自定义数据命名约定双击事件总结前言: 相信大家肯定处理过很多的事件监听,...
    99+
    2024-04-02
  • Vue如何自定义指令回顾v-内置指令
    这篇文章主要介绍了Vue如何自定义指令回顾v-内置指令,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Vue.js 的各种指令(Directi...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作