Angular-在许多组件中使用相同的函数,如何在这种情况下保持DRY?
创始人
2024-10-21 09:30:30
0

一种解决方法是使用Angular Service。将共享的函数作为Service的方法的一部分,并将Service注入到组件中以获取共享函数的访问。这样,当函数需要更改时,只需要更新Service中的代码即可,而所有使用该Service的组件将自动更新。

示例代码:

// service file import { Injectable } from '@angular/core';

@Injectable({ providedIn: 'root' }) export class SharedService {

sharedFunction() { console.log('This is a shared function.'); }

}

// component file import { Component } from '@angular/core'; import { SharedService } from './shared.service';

@Component({ selector: 'app-home', template:

Home Component

, }) export class HomeComponent { constructor(private sharedService: SharedService) {}

sharedFunction() { this.sharedService.sharedFunction(); } }

// another component file import { Component } from '@angular/core'; import { SharedService } from './shared.service';

@Component({ selector: 'app-about', template:

About Component

, }) export class AboutComponent { constructor(private sharedService: SharedService) {}

sharedFunction() { this.sharedService.sharedFunction(); } }

在这个例子中,SharedService类定义了名为sharedFunction()的共享函数。HomeComponentAboutComponent组件都需要使用该函数,所以它们都注入了SharedService

在每个组件中,sharedFunction()方法被定义为使用this.sharedService.sharedFunction()调用。这使得SharedService中定义的同名函数可以在组件中共享且不需要重复定义。

注意:如果在组件中不使用@Input或@Output连接两个组件,则使用Service。但是,如果在组件之间传递数据,则

相关内容

热门资讯

据统计!wepoker作必弊方... 据统计!wepoker作必弊方法,微信超级三加一免费辅助,原来是有辅助软件(哔哩哔哩)暗藏猫腻,小编...
必备透视!sohoo竞技联盟辅... 必备透视!sohoo竞技联盟辅助器,红龙poker辅助平台(透视)总是真的是有辅助插件(哔哩哔哩)1...
于此同时!wepoker破解版... 于此同时!wepoker破解版内购,西元文山攻略,竟然真的是有辅助攻略(哔哩哔哩)wepoker破解...
解迷透视!poker worl... 解迷透视!poker world辅助器,哈糖大菠萝怎么挂(透视)真是一直总是有辅助软件(哔哩哔哩);...
来临!德普之星透视辅助插件,牛... 来临!德普之星透视辅助插件,牛魔王辅助器,其实是真的有辅助攻略(哔哩哔哩)1、每一步都需要思考,不同...
揭幕透视!poker红龙辅助,... 揭幕透视!poker红龙辅助,hardrock透视工具(透视)总是一直都是有辅助技巧(哔哩哔哩)ha...
目前!智星德州插件怎么下载,福... 目前!智星德州插件怎么下载,福建宁德麻将辅助软件,总是是有辅助脚本(哔哩哔哩)1、让任何用户在无需智...
解谜透视!cloudpoker... 解谜透视!cloudpoker作必弊,智星德州插件怎么下载(透视)其实存在有辅助软件(哔哩哔哩)1、...
为切实保障!wepoker免费... 为切实保障!wepoker免费脚本咨询,欢乐联盟辅助器,原来存在有辅助工具(哔哩哔哩)1、用户打开应...
解迷透视!pokemmo辅助器... 解迷透视!pokemmo辅助器,fishpoker透视底牌(透视)切实是有辅助软件(哔哩哔哩)1、进...