浅谈利用Angular指令怎么保持关注点分离?
时间:2021-09-17
来源:互联网
今天PHP爱好者给大家带来利用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,
});
});
}
}
但是,现在我们有更多的地方使用这段分析的接口,我们并不想重复的编写同样的代码。有人可能提出这段代码可以合并到日期选择器中并作为输入参数传递。
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>
以上就是浅谈利用Angular指令怎么保持关注点分离?的详细内容,更多请关注php爱好者其它相关文章!
-
抹茶交易所 时间:2025-05-10
-
GQ币总量多少?GQ币发行量介绍 时间:2025-05-10
-
klarna是什么 时间:2025-05-10
-
GQ是什么币种?GQ币怎么样? 时间:2025-05-10
-
比特币减半时间2024 时间:2025-05-10
-
HMSTR币怎么买?HMSTR币买卖交易操作教程 时间:2025-05-10
今日更新
-
css怎么隐藏border
阅读:18
-
css如何设置行内间隔
阅读:18
-
php composer 无法下载安装包怎么办
阅读:18
-
html需要转义的字符有哪些
阅读:18
-
php不能开启php_curl怎么办
阅读:18
-
php对于unix时间戳的转换方法
阅读:18
-
css怎么写六边形
阅读:18
-
怎么解决uni-app入坑集合
阅读:18
-
新手篇:利用ps旋螺制作花瓣效果(分享)
阅读:18
-
总结分享20个关于Redis的经典面试题(附答案分析)
阅读:18