设计模式——使用TypeScript实现代理模式

代理模式

举例:
使用真实服务器访问网络时,可以使用一个代理服务器进行联网之前的检查,再继续执行访问网络的操作。

代码示例:

//创建用于实现服务器类的通用接口
interface Network {
  //浏览网页的方法
  browse(): void;
}

//创建真实服务器类,实现Network接口
class Server implements Network {
  //真实服务器浏览网页的方法
  browse(): void {
    console.log('真实服务器访问网络');
  }
}

//创建代理服务器类,实现Network接口
class ProxyServer implements Network {
  private netWork: Network;
  
  //使用多态,传入Network类型的类
  constructor(netWork: Network) {
    this.netWork = netWork;
  }
  
  //联网之前的检查方法
  check(): void {
    console.log('联网之前的一些检查工作');
  }
  //代理服务器浏览网页的方法
  //实则代理真实服务器的浏览网页方法
  browse(): void {
    this.check();
    this.netWork.browse();
  }
}


const trueServer = new Server();
const proxyServer: ProxyServer = new ProxyServer(trueServer);

proxyServer.browse();//联网之前的一些检查工作   真实服务器访问网络
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱学习的前端小黄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值