JavaScript设计模式之外观模式

本文介绍JS中的外观模式,一种解决兼容性问题的设计模式。通过封装统一接口,如事件绑定方法bindEvent,使不同浏览器间代码调用保持一致,提高代码可维护性和复用性。

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

外观模式

外观模式,顾名思义,外表看起来相同,但实际可能不一致。在JS中外观模式通常用于处理兼容性问题。比如封装了一个bindEvent事件绑定方法,不同的浏览器会调用bindEvent内部封装的浏览器所支持的方法。

外观模式封装示例


 myEvent = {
        stop: function (e) {
            if (typeof e.preventDefault() === "function") {
                return e.preventDefault();
            }
            if (typeof e.stopPropagation() === "function") {
                return e.stopPropagation();
            }
            //for IE
            if (typeof e.returnValue === "boolean") {
                return (e.returnValue = false);
            }
            if (typeof e.cancelBubble === "boolean") {
                return (e.cancelBubble = true);
            }
        },
        bindEvent(dom, type, fn) {
            if (dom.addEventListener) {
                dom.addEventListener(type, fn, false);
            } else if (dom.attachEvent) {
                dom.attachEvent('on' + type, fn);
            } else {
                dom['on' + type] = fn;
            }
        }
    }
    myEvent.bindEvent(document.querySelector('button'), 
    	'click', () => console.log('button clicked'))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值