美文网首页
javascript适配器模式----2022-11-20

javascript适配器模式----2022-11-20

作者: 前端Tree | 来源:发表于2022-11-19 23:16 被阅读0次
/**
 * 概念:适配器模式
 * 将一个类(对象)的接口(方法或者属性)转化成另外一个接口,以满足用户需求,使类(对象)之间接口
 * 的不兼容问题通过适配器得以解决
 */

// 1、juqery 适配器
// window.A = A = jquery

// 2、适配异类框架
// 假如有这么一个A类框架
// 定义框架
var A = A || {};
// 通过ID 获取元素
A.g = function(id) {
    return document.getElementById(id)
}
// 为元素绑定事件
A.on = function(id, type, fn) {
    // 如果传递参数是字符串则以id处理,否则以元素对象处理
    var dom = typeof id === 'string'? this.g(id) : id;
    // 标准 DOM2 级添加事件方式
    if (dom.addEventListener) {
        dom.addEventListener(type, fn, false);
        // IE DOM2 级添加事件方式
    } else if(dom.attachEvent) {
        dom.attachEvent('on' + type, fn);
        // 简易添加事件方式
    } else {
        dom['on' + type] = fn
    }
}

// 用例
A.on(window, 'load', function() {
    // 按钮点击事件
    A.on('mybutton', 'click', function() {
        console.log('点击成功')
    })
})

// 加入之前我们用的A框架写的代码,现在想转换为jquery,那么我们需要写一个适配器,适配以前的代码
// 下面是适配器
A.g = function(id) {
    // 通过jquery 获取jquery 对象,然后返回第一个成员
    return $(id).get(0)
}

A.on = function(id, type, fn) {
    // 如果传递参数是字符串则以id 处理,否则以元素对象处理
    var dom = typeof id === 'string' ? $('#' + id) : $(id);
    dom.on(type, fn);
}
// end


/**
 * 参数适配器
 * 比如我们封装一个方法需要传很多参数,然而我们一个一个传,是很难记住每一个参数的
 * 因此我们的做法是传递一个对象过去,使用此种方法,就要用适配器来适配传入的这个参数对象,给默认值
 * 
 */

function doSomeThing(obj) {
    var _adapter = {
        name: '王亚浩',
        title: '设计模式',
        age: 24,
        color: 'pink',
        size: 100,
        prize: 50
    };
    for (let i in _adapter) {
      _adapter[i]  = obj[i] || _adapter[i];
    }
    // 或者extend(_adapter, obj) 注此时可能会多添加属性
}

// 数据适配
// 元数据
var arr = ['javascript', 'book', '前端编程语言', '8月1日']
// 目标数据结构
var obj = {
    name:'',
    type:'',
    title:'',
    time:''
}

function arrToObjAdapter (arr) {
    return {
        name: arr[0],
        type: arr[1],
        title: arr[2],
        data: arr[03],
    }
}

// 用例
var adapterData = arrToObjAdapter(arr)
console.log(adapterData)

相关文章

  • Java设计模式(二)

    talk is cheap show me the code 适配器模式 类适配器模式 接口适配器模式 对象适配器...

  • 适配器模式

    目录 1、什么是适配器模式? 2、适配器模式结构? 3、如何实现适配器模式? 4、适配器模式的特点? 5、适配器模...

  • 组合模式设计

    一、设计模式 javascript里面给我们提供了很多种设计模式: 工厂、桥、组合、门面、适配器、装饰者、享元、代...

  • 装饰者模式设计

    一、设计模式 javascript里面给我们提供了很多种设计模式: 工厂、桥、组合、门面、适配器、装饰者、享元、代...

  • 适配器模式

    一、设计模式 javascript里面给我们提供了很多种设计模式: 工厂、桥、组合、门面、适配器、装饰者、享元、代...

  • javascript适配器模式

    适配器模式是为了解决软件实体间的接口不兼容性。使用适配器以后原本不兼容的两个软件的接口可以工作在一起了。宗旨是不要...

  • JavaScript适配器模式

    适配模式的作用是解决两个软件实体间的接口不兼容问题。使用适配器模式之后,原本由于接口不兼容而不能工作的两个软件实体...

  • 设计模式之适配器模式

    适配器模式: 类适配器模式、对象适配器模式、接口适配器模式 1.类适配器模式:新的接口出现了,但是和老的接口不兼容...

  • 学习iOS设计模式第一章 适配器(Adapter)

    今天学习了iOS设计模式中的适配器模式,适配器有两种模式对象适配器模式-- 在这种适配器模式中,适配器容纳一个它包...

  • 第4章 结构型模式-适配器模式

    一、适配器模式简介 二、适配器模式的优点 三、适配器模式的实例

网友评论

      本文标题:javascript适配器模式----2022-11-20

      本文链接:https://www.haomeiwen.com/subject/idyixdtx.html