Angular指令怎么保持关注点的分离
发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,小编给大家分享一下Angular指令怎么保持关注点的分离,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!假设在我们的应用程序
千家信息网最后更新 2024年11月19日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 } ); }); }}
现在可以在每次使用日期选择器时使用它了。
以上是"Angular指令怎么保持关注点的分离"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
日期
分析
选择
指令
接口
组件
关注点
篇文章
事件
代码
内容
教程
更多
不怎么
位置
信息
参数
地方
大部分
应用程序
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
非结构化数据 关系型数据库
关于网络安全的倡议书250字
地球化学数据库技术报告
服务器ddr4
服务器主机开机无显示
软件开发宣传语
原神什么服务器可以手机登录
汕头软件开发团队
网络安全教育活动记载
北京华品网络技术有限公司
it软件开发难不难学
游戏软件开发公司的
新网络安全管理制度
服务器管理员权限设置
pilosa位图数据库教程
组织开展网络安全风险隐患排查
手机联网无法连接服务器
互联网科技公司的平台运营
沧州名扬网络技术
服务器端出错清联系管理员
内蒙古集美网络技术有限公司
数据库极限的定义
服务器怎么假设游戏
湖南网络技术创新服务
软件开发模型h
双核4G服务器租金管理费
网络技术和信息处理专业
从记录集中提取数据库
拷贝mysql数据库文件有用吗
服务器怎么做防护