我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何进行JavaScript设计模式入门和框架中的使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何进行JavaScript设计模式入门和框架中的使用

本篇文章为大家展示了如何进行JavaScript设计模式入门和框架中的使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

在编写JS和组装代码的过程中,运用一定的设计模式可以让我们的代码更加优雅、灵活。

下面笔者就结合诸如redux的subsscribe、ES6的class、vue里面的$dispatch、jquery里面的on/off来给大家简单介绍下设计模式在这些库、语法和框架中的使用。

 设计模式解决的问题

设计模式并不是很玄乎的知识,很多同学在编写JS代码的时候已经在不经意间用了不少设计模式了。

笔者认为把设计模式单独抽象出来探讨,就和算法中抽象出来冒泡、排序一样,是为了描述一种常用的JS pattern。

通过研习这类pattern,让模式来指导我们的代码结构及JS算法。

 一些常用的设计模式概述

observer [观察者模式]

根据状态的变化主动触发观察者队列、hashMap的回调行为

一个简单的观察者模式代码实践

class StateTracker{
        constructor(){
            this.observers = [];
            this.internamState= 10;
        }
        // 改变内部状态,触发状态的观察者列表
        change(val){
            this.internamState= val;
            this.observers.forEach(observer=>observer(val));
        }
        registerObserver(ObserverFn){
            this.obserers.push(ObserverFn)
        }
    }

publish/subscribe [订阅发布模式]

在代码模块的共享访问空间存储hashMap的topic/callback形式。

添加on/off/trigger等接口实现挂载、移除、触发等动作。

一个简单的订阅发布模式代码实践

class PubSubHandler{
        constructor(){
            this.eventPool = {};
        }
        //移除
        off(topicName){
            delete this.observers[topicName]
        }
        //发布
        trigger(topicName,...args){
            this.eventPool[topicName] && 
            this.eventPool[topicName].forEach(callback=>callback(...args));
        }
        //订阅
        on(topicName,callback){
            let topic = this.eventPool[topicName] ;
            if(!topic){
                this.eventPool[topicName] =[]
            }
            this.eventPool[topicName].push(callback)
        }
    }

singleton[单例模式]

构造函数的实例只有一个,一般是通过闭包存储内部实例,通过接口访问内部实例。

var singleton = ()=>{
        var instance;
        var createInstance = ()=>{
            this.a = 1;
            this.b = 2;
        }
        return {
            getInstance:()=>{
                if(!instance){
                    instance = createInstance();
                }
                return instance;
            }
        }
    }
    var test = singleton();
    test.getInstance() == test.getInstance() //true

decorator混合模式

这个模式就是在原有的对象上面装饰更多行为,并且保持变量名不变。 用过ES7的@decorator或者python等语言的,应该对decorator不陌生的。

function decorator(sourceObj,decortorFn){
        decortorFn(sourceObj);
        return sourceObj
    }
    var d = {a:1};
    // d变为了{a:1,b:1}
    d = decorator(d,(d)=>{d.b=1});

  mixin混合模式

这个模式和decorator有点类似,只是它的功能更加垂直。 就是在原有的对象上面增加、覆盖对象的行为。  相比于extends、Object.assign等方法,mixin模式更富有表现力。mixin模式不能一概而论,可能依据不同的数据类型有不同的mixin策略,比如vue.mixin

class StateTracker{
        constructor(){
            this.raw = {
                a:1,
                b:2
            }
        }
        mixin(obj){
            Object.assign(this.raw,obj)
        }
    }

笔者就暂时先介绍这么多设计模式,下面就针对常用的框架、语法、库等来说明这些设计模式的应用。

 observer模式在redux中的使用

var store = createStore(reducer,initialState);
    //注册redux store,存储在 nextListeners数组
    var test = store.subscribe(()=>{console.log('我注册了!')});
    // 取消注册监听
    test.unsubscribe();

 publish/subscribe在jquery中的使用

$(document).on('hello',()=>{console.log('hello')})
    $(document).trigger('hello');
    $(document).off('hello')

 decorator模式在react-redux中的实践

//装饰器
    @connect(state=>state)
    class Container extends Component{
        render(){
            return JSON.stringify(this.props)   
        }
    }

上述内容就是如何进行JavaScript设计模式入门和框架中的使用,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何进行JavaScript设计模式入门和框架中的使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

使用golang框架如何进行分布式计算?

使用 golang 实现分布式计算的分步指南:安装分布式计算框架(如 celery 或 luigi)创建封装任务逻辑的 golang 函数定义任务队列将任务提交到队列设置任务处理程序函数使用 GoLang 进行分布式计算实战分布式计算是一
使用golang框架如何进行分布式计算?
2024-05-24

如何进行iOS界面中框架QMUIKit的使用

这篇文章给大家介绍如何进行iOS界面中框架QMUIKit的使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。对于移动APP来说,客户端(iOS或android)的界面开发是必不可少的工作。为了减轻界面开发的工作量,也为
2023-06-19

如何使用设计模式优化 PHP 函数的架构和性能?

通过应用设计模式,例如单例模式、观察者模式和工厂模式,可以优化 php 函数的架构和性能,包括:单例模式:确保类只有一个实例,提高全局资源访问效率。观察者模式:允许对象通知多个观察者事件更改,提高事件响应效率。工厂模式:在运行时创建不同类型
如何使用设计模式优化 PHP 函数的架构和性能?
2024-04-25

如何使用MySQL进行表的设计和规范化?

如何使用MySQL进行表的设计和规范化?MySQL是一种常用的关系型数据库管理系统,被广泛应用于各种软件开发和数据存储需求中。在使用MySQL进行表的设计和规范化时,遵循一定的原则和规则可以提高数据库的性能和可维护性。本文将介绍如何使用My
2023-10-22

C#开发中如何使用WPF和WinForms进行界面设计

C#开发中如何使用WPF和WinForms进行界面设计引言:在C#开发中,界面设计是一个重要的环节。有多种界面设计工具和框架可供选择,比如Windows Presentation Foundation(WPF)和Windows Forms(
2023-10-22

如何使用Python中的面向对象设计模式

如何使用Python中的面向对象设计模式,需要具体代码示例概述:在Python编程中,面向对象设计模式是非常重要的一个概念。它提供了一种结构化的方法来解决问题,并使得代码更易于理解、维护和扩展。本文将介绍几种常见的面向对象设计模式,并提供具
2023-10-22

如何进行Java代理设计模式的静态代理和动态代理实现

今天就跟大家聊聊有关如何进行Java代理设计模式的静态代理和动态代理实现,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。面试问题:Java里的代理设计模式一共有几种实现方式?这个题目很
2023-06-02

如何利用进行JARVIS美团即时物流的分布式系统架构设计

这期内容当中小编将会给大家带来有关如何利用进行JARVIS美团即时物流的分布式系统架构设计,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 背景美团外卖已经发展了五年,即时物流探索也经历了 3 年多的时间,
2023-06-19

编程热搜

目录