JavaScript代理模式与开发实践(上)

文章介绍了代理模式的概念,通过实例解释了为何及如何在前端开发中使用代理模式,以实现单一职责原则和资源懒加载等效果。作者通过小狗喂食的例子展示了代理如何控制对对象的访问,并提到在下一章将讨论保护代理和虚拟代理。

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

前言

作为一个前端切图仔,少有和各类设计模式打交道。但这不影响我们学习设计模式的思维,来提升我们的代码水平。

本章通过讲解代理模式,希望能够让你对设计模式更一步的学习。

本章学习内容👇

  • 认识代理模式
  • 完成一个代理模式

代理模式

什么是代理模式

代理模式: 为一个对象提供一个代用品或占位符,以便控制对它的访问。

以日常开发的角度将:就是将一个方法/对象处理前,交给另外一个方法/对象代替处理,起到以下几个方面好处的效果:

  • 实现单一职责原则:指一个类或者模块应该有且只有一个改变的原因。

  • 在调用目标方法前,通过代理判断来节约资源

    • 可能会有条件不满足的情况
    • 可能会有已经使用的情况
  • 控制对象/方法的访问权

  • 资源懒加载等等

实现一个基本的代理

example:

小明养了一只小狗—爱德华。由于出差,小明爱德华寄养到了宠物店。然后通过联系宠物店老板来照顾喂食小狗。

试想这个地方为什么要用代理呢?原因👇

小明想要喂养小狗食物的时候,他是无法直接自己喂的。因为爱德华已经被寄养在宠物店,小明是没有办法直接自己喂的。而这个时候就需要一个通过一个代理对象—即宠物店小明只有通过联系宠物店,才能够喂养爱德华。而宠物店,又能够监听到爱德华饥饿状态,只有当爱德华饥饿时才喂。这又避免了爱德华的无用进食。现在能感受到代理的魅力了吗?

code:

let xiaoming = {
    proxyFeed:function(target){
        //通过代理对象喂养
        target.feedPet(aidehua)
    }
}
​
let aidehua ={
    eat:function(){
        aidehua.hp ++
        setInterval(()=>{
            //生命消耗
            aidehua.hp--
        },10000)
    },
    hp:0
}
​
let petShop = {
    feedPet:function(target){
        if(target.hp < 1){
            //只有饥饿时才喂食
            target.eat()
        }
    }
}
​
xiaoming.proxyFeed(petShop)

尾声

代理模式的思想在前端日常开发中也时常能够运用上,希望你能够掌握它。
在下一章中,会讲解有关代理的俩个主要模式——保护代理&虚拟代理,欢迎阅读.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值