Angular指令怎么保持关注点的分离
发表于:2025-11-18 作者:千家信息网编辑
千家信息网最后更新 2025年11月18日,小编给大家分享一下Angular指令怎么保持关注点的分离,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!假设在我们的应用程序
千家信息网最后更新 2025年11月18日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安全错误
数据库的锁怎样保障安全
沈阳哪有招聘软件开发的
浪潮服务器添加物理网卡不通
阿里云服务器ssh
安卓开发删除数据库表
浙江统一软件开发价格标准
csgo躲猫猫服务器商店
计算机网络技术与应用课本
文献数据库官网
滨州网络安全分行
上海小软件开发公司
为什么罗布乐思关闭服务器了
安徽信一企互联网科技
电脑客户端软件开发
执业药师数据库
软件工程数据库物理模型
鹤壁浚县软件开发
毕设系统服务器未知错误
嵌入式服务器无法登陆访问
计算网络技术基础段标
删除数据库怎么恢复连接
服务器地址查询
oppo的手机软件开发部门
服务器安装软件后再开机看不到
长乐软件开发
网络安全高级工程师职称评审
茅箭区互联网软件开发专业服务
初之数据库
软件开发工程师培训内容
新华三的软件开发做什么
即时聊天软件开发文献