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月前
|
设计模式 数据安全/隐私保护
Next.js 实战 (七):浅谈 Layout 布局的嵌套设计模式
这篇文章介绍了在Next.js框架下,如何处理中后台管理系统中特殊页面(如登录页)不包裹根布局(RootLayout)的问题。作者指出Next.js的设计理念是通过布局的嵌套来创建复杂的页面结构,这虽然保持了代码的整洁和可维护性,但对于特殊页面来说,却造成了不必要的布局包裹。文章提出了一个解决方案,即通过判断页面的skipGlobalLayout属性来决定是否包含RootLayout,从而实现特殊页面不包裹根布局的目标。
81 33
|
3月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
53 2
|
4月前
|
设计模式 JavaScript 前端开发
JavaScript设计模式--访问者模式
【10月更文挑战第1天】
47 3
|
6月前
|
设计模式 JavaScript 前端开发
从工厂到单例再到策略:Vue.js高效应用JavaScript设计模式
【8月更文挑战第30天】在现代Web开发中,结合使用JavaScript设计模式与框架如Vue.js能显著提升代码质量和项目的可维护性。本文探讨了常见JavaScript设计模式及其在Vue.js中的应用。通过具体示例介绍了工厂模式、单例模式和策略模式的应用场景及其实现方法。例如,工厂模式通过`NavFactory`根据用户角色动态创建不同的导航栏组件;单例模式则通过全局事件总线`eventBus`实现跨组件通信;策略模式用于处理不同的表单验证规则。这些设计模式的应用不仅提高了代码的复用性和灵活性,还增强了Vue应用的整体质量。
90 1
|
6月前
|
设计模式 JavaScript 前端开发
小白请看 JS大项目宝典:设计模式 教你如何追到心仪的女神
小白请看 JS大项目宝典:设计模式 教你如何追到心仪的女神
|
7月前
|
设计模式 JavaScript Go
js设计模式【详解】—— 状态模式
js设计模式【详解】—— 状态模式
109 7
|
7月前
|
设计模式 JavaScript
js设计模式【详解】—— 桥接模式
js设计模式【详解】—— 桥接模式
90 6
|
7月前
|
设计模式 JavaScript
js设计模式【详解】—— 原型模式
js设计模式【详解】—— 原型模式
66 6
|
7月前
|
设计模式 JavaScript 前端开发
JavaScript进阶 - JavaScript设计模式
【7月更文挑战第7天】在软件工程中,设计模式是解决常见问题的标准解决方案。JavaScript中的工厂模式用于对象创建,但过度使用可能导致抽象过度和缺乏灵活性。单例模式确保唯一实例,但应注意避免全局状态和过度使用。观察者模式实现了一对多依赖,需警惕性能影响和循环依赖。通过理解模式的优缺点,能提升代码质量。例如,工厂模式通过`createShape`函数动态创建对象;单例模式用闭包保证唯一实例;观察者模式让主题对象通知多个观察者。设计模式的恰当运用能增强代码可维护性。
94 0
|
7月前
|
设计模式 缓存 JavaScript
js设计模式实例
【7月更文挑战第2天】JavaScript设计模式包含工厂、单例、建造者、抽象工厂和代理模式等,它们是最佳实践和可重用模板,解决创建、职责分配和通信等问题。例如,工厂模式封装对象创建,单例确保全局唯一实例,建造者模式用于复杂对象构建,抽象工厂创建相关对象集合,而代理模式则控制对象访问。这些模式提升代码质量、可读性和灵活性,是高效开发的关键。
49 0