JavaScript结构型设计模式---适配器模式

参考书籍:JavaScript设计模式
传统设计模式中,适配器模式往往是适配两个类接口不兼容的问题,然而在javascript 中,应用比较广泛,比如适配两个代码库,适配前后端数据,等等,但是更多的是应用在对象之间,为了使对象可用,通常我们会把对象拆分并重新包装。
框架比较相似的适配器,例如A 框架的代码和jQuery 代码书写比较像,就可以用window.A=A=jQuery;
适配异类框架

//定义框架
var A = A || {}
//获取元素
A.g = function (id) {
    return document.getElementById(id);
}
A.on = function (id, type, fn) {
    //如果传递参数是字符串则以id处理,否则以元素对象处理
    var dom = typeof id === 'string' ? this.g(id) : id;
    if (dom.addEventListener) {
        dom.addEventListener(type, fn, false);
    } else if (dom.attachEvent) {
        dom.attachEvent('on' + type, fn)
    } else {
        dom['on' + type] = fn;
    }
}
//页面点击方法
A.on(window, 'load', function () {
    A.on('mybutton', 'click', function () {
        //do something
    })
});
//适配器--引入jQuery
A.g = function (id) {
    //通过jQuery 获取jQuery对象,然后返回第一个成员
    return $(id).get(0);
}
A.on = function (id, type, fn) {
    var dom = typeof id === 'string' ? $('#' + id) : $(id);
    dom.on(type, fn);

}

参数适配器
当调用一些方法的时候不知道传递的参数是否完整,如有些是必须的但是没有传入,一些是默认值等等,此时我们通常的做法是用适配器来参入这个参数
如下

function doSome(o) {
    var adapter = {
        name: 'argAdapter',
        title: 'design',
        color: 'purple',
        size: 100,
        price: 20
    };
    for (var i in adapter) {
        adapter[i] = o[i] || adapter[i];
    }
    console.log(JSON.stringify(adapter));
    //使用
        doSome({
        name: 'obj1',
        title: 'test',
        color: 'red',
        size: 37,
        price: 56
    });//{"name":"obj1","title":"test","color":"red","size":37,"price":56}
    doSome({
        name: 'obj2',
        title: 'test2',
        color: 'black'
    });//{"name":"obj2","title":"test2","color":"black","size":100,"price":20}
    doSome({
        title: 'test3',
        name: 'obj3',
        color: 'white'
    });//{"name":"obj3","title":"test3","color":"white","size":100,"price":20}
    doSome({
        count: 37,
        price: 56
    });//{"name":"argAdapter","title":"design","color":"purple","size":100,"price":56}

}

数据适配器

服务器端数据适配器

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MVVM 是一种前端架构设计模式,它将界面、数据和逻辑分离并通过 ViewModel 进行交互。在 MVVM 模式中,视图(View)和模型(Model)是完全独立的,它们通过 ViewModel 进行双向绑定(Binding)。 在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式。Vue.js 的数据驱动视图,通过数据改变来更新视图,这些数据是被劫持的,也就是说,当数据发生变化时,Vue.js 会自动更新视图。 Vue.js 中的 MVVM 模式包含以下三个部分: 1. 视图层(View):负责展示数据,通常是 HTML 模板。 2. 模型层(Model):负责存储数据,通常是 JavaScript 对象。 3. 视图模型层(ViewModel):负责处理视图与模型之间的交互,它是一个纯粹的 JavaScript 对象,负责实现数据绑定、数据格式化、事件监听等功能。 在 Vue.js 中,我们可以使用指令(v-directive)来实现数据绑定。指令是一种特殊的 HTML 属性,它的值通常是一个表达式,用来绑定指令所在元素的属性或事件。例如,v-bind 指令可以将一个 JavaScript 对象绑定到 DOM 元素的属性,v-on 指令可以监听 DOM 元素的事件。 除了指令之外,Vue.js 还提供了计算属性(Computed)和侦听器(Watch)等功能,用于处理数据的计算和监听数据的变化。 总之,MVVM 模式是一种前端架构设计模式,它通过 ViewModel 实现视图(View)和模型(Model)之间的双向绑定(Binding),实现了数据的自动更新和视图的响应式。在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值