[Angular Directive] Combine HostBinding with Services in Angular 2 Directives

You can change behaviors of element and @Component properties based on services using @HostBinding in @Directives. This allows you to build @Directives which rely on services to change behavior without the @Component ever needing to know that the Service even exists.

 

复制代码
import {Directive, HostBinding} from '@angular/core';
import {OnlineService} from "../services/online.service";

@Directive({
  selector: '[online]'
})
export class OnlineDirective {

  constructor(private onlineService: OnlineService) { }

  @HostBinding('style.color') get styleColor () {
    return !this.onlineService.online ? 'red': 'unset';
  }
  @HostBinding('disabled') get disabled() {
    return !this.onlineService.online;
  }
}
复制代码

 

复制代码
@Injectable()
export class OnlineService{
    online = true
    constructor(){
        setInterval(()=>{
            this.online = Math.random() > .5
        }, 1000)
    }
}
复制代码

 

<button online>One</button>

 

posted @   Zhentiw  阅读(551)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2015-12-22 [Polymer] Introduction
2015-12-22 [Redux] Implementing combineReducers() from Scratch
2015-12-22 [Redux] Reducer Composition with combineReducers()
2014-12-22 [Bower] Bower
点击右上角即可分享
微信分享提示