返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用AngularJS2中的指令
  • 605
分享到

如何使用AngularJS2中的指令

2024-04-02 19:04:59 605人浏览 泡泡鱼
摘要

这篇文章主要介绍如何使用angularjs2中的指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!这次我们使用Angular2的指令来实现。指令实现hover效果import&nbs

这篇文章主要介绍如何使用angularjs2中的指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

这次我们使用Angular2的指令来实现。

指令实现hover效果

import { Directive, ElementRef, HostListener, Input } from '@angular/core';
@Directive({
 selector: '[myHighlight]'
})
export class HighlightDirective {
 constructor(private el: ElementRef) { }
 @HostListener('mouseenter') onMouseEnter() {
 this.highlight('red');
 }
 @HostListener('mouseleave') onMouseLeave() {
 this.highlight(null);
 }
 private highlight(color: string) {
 this.el.nativeElement.style.backgroundColor = color;
 }
}
<button myHighlight class="btn">按钮一</button>
<button myHighlight class="btn">按钮二</button>
<button myHighlight class="btn">按钮三</button>
.btn{
 height: 50px;
 width: 100px;
 background-color: #3399ff;
 color: white;
 border: 0;
 outline: 0;
 cursor: hand;
}

hover的效果直接参考Angular官网的代码。

如何使用AngularJS2中的指令 

指令实现click效果

import { Directive, ElementRef, HostListener, Input } from '@angular/core';
@Directive({
 selector: '[myHighlight]'
})
export class HighlightDirective {
 constructor(private el: ElementRef) { }
 @HostListener('click') onMouseClick() {
 this.clickhighlight("black");
 }
 private clickhighlight(color: string) {
 let obj = this.el.nativeElement;
 let btns = obj.parentnode.children;
 //背景色全部重置
 for(let i=0; i<btns.length; i++){
 btns[i].style.backgroundColor = "#3399ff";
 }
 //设置当前点击对象的背景色
 obj.style.backgroundColor = color;
 }
}
<div>
<button myHighlight class="btn">按钮一</button>
<button myHighlight class="btn">按钮二</button>
<button myHighlight class="btn">按钮三</button>
</div>
.btn{
 height: 50px;
 width: 100px;
 background-color: #3399ff;
 color: white;
 border: 0;
 outline: 0;
 cursor: hand;
}

click效果仍然用@HostListener装饰器引用属性型指令的宿主元素,首先把所有button的背景颜色重置,然后再设置当前点击对象的背景颜色,这样就达到了点击后背景颜色变化的效果。

如何使用AngularJS2中的指令 

指令实现click加hover效果

import { Directive, ElementRef, HostListener, Input } from '@angular/core';
@Directive({
 selector: '[myHighlight]'
})
export class HighlightDirective {
 constructor(private el: ElementRef) { }
 @HostListener('click') onMouseClick() {
 this.clickhighlight("black");
 }
 private clickhighlight(color: string) {
 let obj = this.el.nativeElement;
 let btns = obj.parentNode.children;
 //背景色全部重置
 for(let i=0; i<btns.length; i++){
 btns[i].style.backgroundColor = "#3399ff";
 }
 //设置当前点击对象的背景色
 obj.style.backgroundColor = color;
 }
}
<div>
<button myHighlight class="btn">按钮一</button>
<button myHighlight class="btn">按钮二</button>
<button myHighlight class="btn">按钮三</button>
</div>
.btn{
 height: 50px;
 width: 100px;
 background-color: #3399ff;
 color: white;
 border: 0;
 outline: 0;
 cursor: hand;
}
.btn:hover{
 background: black !important;
}

配合上文click效果,只要加上一行CSS代码就可以实现click和hover的组合效果,此处务必使用hover伪类,并用!important来提升样式的优先级,如果用@HostListener装饰器,mouseenter、mouseleave、click三者会打架:

如何使用AngularJS2中的指令 

以上是“如何使用AngularJS2中的指令”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网VUE频道!

--结束END--

本文标题: 如何使用AngularJS2中的指令

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

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

猜你喜欢
  • 如何使用AngularJS2中的指令
    这篇文章主要介绍如何使用AngularJS2中的指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!这次我们使用Angular2的指令来实现。指令实现hover效果import&nbs...
    99+
    2024-04-02
  • AngularJS2中如何实现Http服务
    这篇文章主要介绍了AngularJS2中如何实现Http服务,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。关于http服务HttpModul...
    99+
    2024-04-02
  • C#中using指令如何使用
    C#中using指令如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1.using指令。using + 命名空间名字,这样可以在程序中直接用命令空间中的类型,而不必指...
    99+
    2023-06-17
  • vscode中如何使用webpack指令
    vscode中如何使用webpack指令,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。在学习Vue的时候,在vscode的终端总使用webpack指令时,出现如...
    99+
    2023-06-20
  • C++ 中如何使用cpuid指令
    这篇文章将为大家详细讲解有关C++ 中如何使用cpuid指令,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、什么是C++ cpuid指令CPUID指令是intel IA32架构下获得CPU...
    99+
    2023-06-17
  • dos中如何使用color指令
    这篇文章主要介绍了dos中如何使用color指令,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。颜色 对于当前会话,更改命令提示窗口的前景和背景色。如果在不含参数的情况下使用,...
    99+
    2023-06-09
  • Vue中v-model指令如何使用
    今天就跟大家聊聊有关Vue中v-model指令如何使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。v-model 用在 input 元素上时v-m...
    99+
    2024-04-02
  • 如何在Shell中使用cut指令
    如何在Shell中使用cut指令?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。cut是以每一行为一个处理对象的,这种机制和sed一样。cut接受三个定位方法:1...
    99+
    2023-06-09
  • set指令如何在shell中使用
    本篇文章给大家分享的是有关set指令如何在shell中使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。语法set [-可选参数] [-o 选项]...
    99+
    2023-06-09
  • Vue.js中v-model指令如何使用
    今天小编给大家分享一下Vue.js中v-model指令如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、v-mode...
    99+
    2023-06-29
  • 如何使用go:linkname指令
    这篇文章主要介绍“如何使用go:linkname指令”,在日常操作中,相信很多人在如何使用go:linkname指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用go:linkname指令”的疑惑有所...
    99+
    2023-06-15
  • Vue指令如何使用
    这篇“Vue指令如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue指令如何使用”文章吧。一、基本使用官网案例:&l...
    99+
    2023-07-04
  • vue中的自定义指令如何使用
    这篇文章主要介绍“vue中的自定义指令如何使用”,在日常操作中,相信很多人在vue中的自定义指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中的自定义指令如何使用”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-29
  • angular的scopel指令如何使用
    这篇文章主要介绍了angular的scopel指令如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇angular的scopel指令如何使用文章都会有所收获,下面我们一起来...
    99+
    2024-04-02
  • JSP的include指令如何使用
    JSP的include指令用于将一个JSP页面包含到另一个JSP页面中。使用include指令可以实现代码的重用和模块化。下面是in...
    99+
    2023-08-12
    JSP include
  • Linux的curl指令如何使用
    这篇文章主要介绍“Linux的curl指令如何使用”,在日常操作中,相信很多人在Linux的curl指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux的curl指令如何使用”的疑惑有所帮助!...
    99+
    2023-07-05
  • redis如何使用scan指令代替keys指令
    这篇文章主要为大家展示了“redis如何使用scan指令代替keys指令”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“redis如何使用scan指令代替keys...
    99+
    2024-04-02
  • Vue中如何使用自定义指令
    今天就跟大家聊聊有关Vue中如何使用自定义指令,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.自定义指令的语法Vue自定义指令语法如下:Vue.d...
    99+
    2024-04-02
  • 如何使用v-model指令
    这篇文章主要介绍“如何使用v-model指令”,在日常操作中,相信很多人在如何使用v-model指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用v-model指令”...
    99+
    2024-04-02
  • Angular的结构指令如何使用
    这篇文章主要介绍“Angular的结构指令如何使用”,在日常操作中,相信很多人在Angular的结构指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Angular的...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作