angularjs 装饰器 Decorator

本文介绍如何使用Angular的装饰器来为已有服务扩展新功能。通过一个具体的例子展示了如何为原有的Mail服务增加抄送功能,使得moduleA在依赖moduleB的情况下能够实现更丰富的邮件发送选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Decorator
装饰, 在已有的功能上锦上添花
Use case 使用场景:

我有一个module A依赖于另外一个module B。 module B有个service Mail, 这个服务提供两个方法setReceiver 和 setBody 分别用来指定邮件的收件人和邮件的内容。 但是在module A 使用Mail服务的时候, 我希望还可以指定抄送的人。 这个时候我就可以在已有的service上扩展下(装饰下)加个addCC的方法。

Java代码  收藏代码
  1. var Mail = function() {  
  2.     this.receiver = '';  
  3.     this.body = '';  
  4.     this.cc = [];  
  5. };  
  6.   
  7. Mail.prototype.setReceiver = function(receiver) {  
  8.     this.receiver = receiver;  
  9. };  
  10.   
  11. Mail.prototype.setBody = function(body) {  
  12.     this.body = body;  
  13. };  
  14.   
  15. angular.module('A', []).service('Mail', Mail);  

Module B

Java代码  收藏代码
  1. angular.module('B', ['A']).config(function($provide) {  
  2.     $provide.decorator('Mail', function($delegate) {  
  3.         $delegate.addCC = function(cc) {  
  4.             this.cc.push(cc);  
  5.         };  
  6.         return $delegate;  
  7.     });  
  8. })  
  9. .controller('TestCtrl', function($scope, Mail) {  
  10.     Mail.addCC('jack');  
  11.     console.log(Mail);  
  12. });  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值