JavaScript设计模式(二十七):未来预言家-委托模式

简介: 未来预言家-委托模式

委托模式(Entrust)

多个对象接收并处理同一请求,他们将请求委托给另一个对象统一处理请求。

点击事件绑定


<ul id="btn-box">
    <li>
        <button class="btn">按钮1</button>
    </li>
    <li>
        <button class="btn">按钮2</button>
    </li>
    <li>
        <button class="btn">按钮3</button>
    </li>
    <li>
        <button class="btn">按钮4</button>
    </li>
    <li>
        <button class="btn">按钮5</button>
    </li>
    <li>
        <button class="btn">按钮6</button>
    </li>
</ul>

循环绑定

let btns = document.querySelectorAll('.btn');
let len = btns.length;

for (let i = 0; i < len; i++) {
   
    btns[i].onclick = function (e) {
   
        this.style.backgroundColor = 'red';
    };
}

委托给父元素,进行事件绑定

let btnBox = document.querySelector('#btn-box');

btnBox.onclick = function (e) {
   
    if (e.target.nodeName === 'BUTTON') {
   
        e.target.style.backgroundColor = 'red';
    }
};

数据分发

原来我们处理数据的方法

// 比如原来我们处理数据是这样的,我们需要请求5此才能完善所有模块
$.get("./deal.php?q=banner", function (res) {
   
    // 处理banner模块逻辑
})
$.get("./deal.php?q=aside", function (res) {
   
    // 处理aside模块逻辑
})
$.get("./deal.php?q=article", function (res) {
   
    // 处理article模块数据
})
$.get("./deal.php?q=member", function (res) {
   
    // 处理member模块数据
})
$.get("./deal.php?q=message", function (res) {
   
    // 处理message模块数据
})

使用了委托模式处理数据的方法

// 使用委托后处理数据是这样的,我们只需要请求一次,就能用不同的方法完善所有模块
var Deal = {
   
    banner: function () {
   
        // 处理banner模块逻辑
    },
    aside: function (res) {
   
        // 处理aside模块逻辑
    },
    article: function (res) {
   
        // 处理article模块数据
    },
    member: function (res) {
   
        // 处理member模块数据
    },
    message: function (res) {
   
        // 处理message模块数据
    }
}
$.get('./deal.php?', function (res) {
   
    //数据拆包分发
    for (var k in res) {
   
        Deal[k] && Deal[k](res[k]);
    }
});

特点

委托模式是通过委托者将请求委托给被委托者去处理实现的。因此委托模式解决了请求与委托者之间的耦合。通过被委托者对接收到的请求的处理后,分发给相应的委托者去处理。

目录
相关文章
|
1月前
|
设计模式 前端开发 JavaScript
【JavaScript 技术专栏】JavaScript 设计模式与实战应用
【4月更文挑战第30天】本文探讨JavaScript设计模式在提升开发效率和代码质量中的关键作用。涵盖单例、工厂、观察者、装饰器和策略模式,并通过实例阐述其在全局状态管理、复杂对象创建、实时数据更新、功能扩展和算法切换的应用。理解并运用这些模式能帮助开发者应对复杂项目,提升前端开发能力。
|
1月前
|
设计模式 前端开发 算法
【面试题】 ES6 类聊 JavaScript 设计模式之行为型模式(二)
【面试题】 ES6 类聊 JavaScript 设计模式之行为型模式(二)
|
2天前
|
设计模式 JavaScript 前端开发
[JavaScript设计模式]惰性单例模式
[JavaScript设计模式]惰性单例模式
|
1天前
|
设计模式 JavaScript 前端开发
JavaScript设计模式——代理模式
JavaScript设计模式——代理模式
|
1月前
|
设计模式 JavaScript 前端开发
js设计模式-观察者模式与发布/订阅模式
观察者模式和发布/订阅模式是JavaScript中的两种设计模式,用于处理对象间的通信和事件处理。观察者模式中,一个主题对象状态改变会通知所有观察者。实现包括定义主题和观察者对象,以及在主题中添加、删除和通知观察者的功能。发布/订阅模式则引入事件管理器,允许发布者发布事件,订阅者通过订阅接收通知。
|
1月前
|
设计模式 Java
【设计模式】JAVA Design Patterns——Business Delegate(业务委托模式)
【设计模式】JAVA Design Patterns——Business Delegate(业务委托模式)
|
1月前
|
设计模式 存储 前端开发
JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发
JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发
|
1月前
|
设计模式 JavaScript 算法
js设计模式-策略模式与代理模式的应用
策略模式和代理模式是JavaScript常用设计模式。策略模式通过封装一系列算法,使它们可互换,让算法独立于客户端,提供灵活的选择。例如,定义不同计算策略并用Context类执行。代理模式则为对象提供代理以控制访问,常用于延迟加载或权限控制。如创建RealSubject和Proxy类,Proxy在调用RealSubject方法前可执行额外操作。这两种模式在复杂业务逻辑中发挥重要作用,根据需求选择合适模式解决问题。
|
1月前
|
设计模式 缓存 JavaScript
js常用设计模式
js常用设计模式
34 1
|
1月前
|
设计模式 算法 前端开发
设计模式-委托模式
设计模式-委托模式
44 1