js设计模式:桥接模式

作用:

可以将复杂的类进行一些拆分,让抽象和实现进行分离解耦,可以让每一个部分都可以单独维护

方便扩展和维护

示例:

javascript 复制代码
        class Obj {
            constructor(person) {
                this.person = person
                this.name = person.name
            }
            getHobby(){
                return this.person.hobby
            }
            getBehavior(){
                return this.person.behavior()
            }
        }

        class Human {
            constructor(hobby) {
                this.name = '打工人'
                this.hobby = hobby
            }
            behavior() {
                console.log('一身打工人的怨气')
            }
        }
        class Deity {
            constructor(hobby) {
                this.name = '神仙'
                this.hobby = hobby
            }
            behavior() {
                console.log('过着神仙般的生活')
            }
        }

        const wjt = new Obj(new Human('抖音刷美女,或者打游戏'))
        const sunwukong = new Obj(new Deity('定身七仙女,然后吃桃子'))

        console.log(wjt.name+'的爱好:'+wjt.getHobby())
        console.log(sunwukong.name+'的爱好:'+sunwukong.getHobby())
相关推荐
北冥有一鲲13 分钟前
A2A协议与LangChain.js实战:构建微型软件工厂
开发语言·javascript·langchain
UIUV31 分钟前
JavaScript 遍历方法详解
前端·javascript·代码规范
火车叼位35 分钟前
开发者必看:三大 CLI 工具 MCP 配置详解
javascript
拾荒李40 分钟前
虚拟列表进阶-手搓不定高虚拟列表实现
javascript·性能优化
Zyx20071 小时前
React 中的 Props:组件通信与复用的核心机制
前端
海云前端11 小时前
大模型Function Calling的函数如何调用的?
前端
ohyeah1 小时前
防抖与节流:前端性能优化的两大利器
前端·javascript
Zyx20071 小时前
React Hooks:函数组件的状态与副作用管理艺术
前端
让我上个超影吧2 小时前
基于SpringBoot和Vue实现CAS单点登录
前端·vue.js·spring boot