Angular指令保持关注点的分离怎么做,方法是什么
Admin 2022-07-29 群英技术资讯 1121 次浏览
这篇文章主要介绍了Angular指令保持关注点的分离怎么做,方法是什么相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Angular指令保持关注点的分离怎么做,方法是什么文章都会有所收获,下面我们一起来看看吧。
假设在我们的应用程序中有一个日期选择器组件。用户每次更改日期的时,都会给分析提供商发送一个事件。到目前位置,我们只使用过一次,所以这个分析接口可以放在使用它的组件中:
header-1.ts
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroyed';
@UntilDestroy()
class FooComponent {
timespanControl = new FormControl();
ngOnInit() {
this.timespanControl.valueChanges
.pipe(untilDestroyed(this))
.subscribe(({ preset }) => {
this.analyticsService.track('timespan-filter apply', {
value: preset,
});
});
}
}但是,现在我们有更多的地方使用这段分析的接口,我们并不想重复的编写同样的代码。有人可能提出这段代码可以合并到日期选择器中并作为输入参数传递。【相关教程推荐:《angular教程》】
data-picker-1.component.ts
class DatePickerComponent {
@Input() analyticsContext: string;
constructor(private analyticsService: AnalyticsService) {}
apply() {
this.analyticsService.track('timespan-filter apply', {
context: this.analyticsContext,
value: this.preset,
});
...
}
}确实,这样可以实现,但是这并不是理想的设计。关注点分离意味着日期选择器本身是和分析接口没有关系的,它也不需要了解任何分析接口的信息。
此外,因为日期选择器是一个内部的组件,我们可以修改他的源码,但是如果是第三方的组件?该如何解决?
这里更好的选择时Angular指令,创建一个指令,通过DI获取表单的引用,订阅内部值的修改来触发分析事件。datePickerAnalytics.directive.ts
@UntilDestroy()
@Directive({
selector: '[datePickerAnalytics]',
})
export class DatePickerAnalyticsDirective implements OnInit {
@Input('datePickerAnalytics') analyticsContext: string;
constructor(
private dateFormControl: NgControl,
private analyticsService: AnalyticsService
) {}
ngOnInit() {
this.dateFormControl
.control.valueChanges.pipe(untilDestroyed(this))
.subscribe(({ preset }) => {
this.analyticsService.track(
'timespan-filter apply',
{
value: preset,
context: this.analyticsContext
}
);
});
}
}现在可以在每次使用日期选择器时使用它了。
<date-picker [formControl]="control" datePickerAnalytics="fooPage"></date-picker>
英文原文地址:https://netbasal.com/maintaining-separation-of-concerns-through-angular-directives-8362ccdf655b
原文作者:Netanel Basal
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
判断方法:1、使用“document.getElementById("id值")”语句根据指定id值获取div元素对象;2、利用if语句判断div是否存在,语法“if (div元素对象){//元素存在}else{//元素不存在}”。
周日历是日常生活中不常用到的历法系统,一般用于政府、商务的会计年度或者学校教学日历中。本文将利用JavaScript制作个简单的周日历,感兴趣的可尝试一下
这篇文章主要介绍了Webpack的Loader和Plugin的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要给大家介绍了关于NodeJs内存占用过高的排查实战记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
依赖模块nodejs-websocket服务端constws=require('nodejs-websocket');console.log('开始建立连接...');constserver=ws.createServer(function(conn){conn.on('text',function(str){console.log('收到的信息为:'
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008