JavaScript设计模式之单例模式

简介: JavaScript设计模式之单例模式

JavaScript 设计模式 之旅

在这里插入图片描述

设计模式开篇

日常开发中,我们都很注重开发技巧,好的开发 技巧可以事半功倍得解决此刻得问题。

那么这些技巧如何来得呢?

我的理解: 经过不断踩坑,解BUG,总结出来一些处理对应问题解决方案,这就所谓的 技巧

说起设计模式,其实我们日常开始中也经常用到,只是你不知道用的解决方案方案对应的设计模式名称.

学习设计模式的作用

在软件设计中,模式是一些经过了大量实际项目验证的优秀解决方案。熟悉这些模式的程序员,对某些模式的理解也会自然的形成条件反射。当遇到合适的场景出现时,可以快速找到对应的模式来处理当前的问题。

单例模式

定义: 保证 类 仅有 一个实例,并可以全局访问这个实例.

全局变量 不是 单例模式,但是在JavaScript 中, 我们经常把单例模式当作全局变量使用。

因为它满足单例模式的两点:

  • 创建的全局变量是独一无二的
  • 它可以全局访问这个变量实例
// login.js
var loginInfo = {
     username: '',
    token: '',
    .......
}



//login.vue

import logins from './login.js'

logins.name =  this.username
但是它也有缺点,容易造成命名空间污染。

定义的全局变量多了, 会覆盖掉之前定义的全局变量,这样会造成不必要的BUG.

如何处理命名空间污染呢?

如何处理呢?

  • 1.使用命名空间
  • 2.使用闭包封装私有变量

命名空间

对象自变量的形式:
// login.js
export default var loginInfo = {
    names:'' ,
    token: '',
    setName: function (name) {
        this.names = name
    },
    getName: function () {
        return this.name
    }
}


//login.vue
import logins from './login.js'

logins.token =  this.token

使用闭包封装私有变量

把一些变量封装在闭包内部,只暴露一些接口跟外界通信。

外界是访问不到 内部定义的私有变量的,这样就避免了全局命令污染。

var user = (function () {
    //外界是访问不了 _name _age 
    var _name = '张三',
        _age = 22;
    
        return {
            //这块留给外界通信用
            getUserInfo: function () {
                console.log(`姓名为:${_name},年龄为:${_age}`) 
            }
        }
})()
                                                                                                                                              
user.getUserInfo()

通用的惰性单例模式

在该执行的情况下,执行操作步骤 / DOM.

优点: 节约了性能。

场景1
有时候,例如登陆弹窗,在加载首页的同时,它会渲染这个页的全部 DOM,如果首页DOM 内容多,加载速度也会相应的很慢,有很多不需要DOM提前渲染。

这时,可以通过惰性单例模式来解决此问题,例如单击了登陆按钮,才会创建登陆弹窗的DOM,并且记录此次点击状态,如果下次还要打开,只是更改 DOM 的 style display 属性即可。 这样节约了首页加载时间,提升页面性能。

// 定义全局通用单例模式
var getSingle = function (fn) {
    var result;
    return function () {
        return result || (result = fn.apply(this, arguments));
    }
}

// 创建登陆窗口
var createLoginLayer =  function() {
    var div = document.createElement('div')
    div.innerHTML = '登陆框'
    div.style.display = 'none'
    document.body.appendChild(div)
    return div
}

//  创建单例模式 登陆框
var createSingleLoginLayer =  getSingle(createLoginLayer);

document.getElementById('btn').onclick = () => {
    // 获取单例模式中 返回得登陆框
    var  loginLayer = createSingleLoginLayer();
    // 改变样式
    loginLayer.style.display = 'block'
}
场景2
创建唯一的 iframe 用于加载第三方页面
var createSingleIframe =  getSingle( function() {
    var iframe = document.createElement('iframe');
    document.body.appendChild(iframe)
    return iframe
})

document.getElementById('redirect').onclick = () => {
    var  iframeLayer = createSingleIframe();
    iframeLayer.src = 'http://www.baidu.com'
}
更多精彩内容,关注公众号: '前端自学社区',获取

本文内容如有错的地方,欢迎各位大佬指正,学习了😆

相关文章
|
2月前
|
设计模式 安全 Java
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
30 2
|
11天前
|
设计模式 存储 前端开发
前端必须掌握的设计模式——单例模式
单例模式是一种简单的创建型设计模式,确保一个类只有一个实例,并提供一个全局访问点。适用于窗口对象、登录弹窗等场景,优点包括易于维护、访问和低消耗,但也有安全隐患、可能形成巨石对象及扩展性差等缺点。文中展示了JavaScript和TypeScript的实现方法。
|
16天前
|
设计模式 安全 Java
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
21 2
|
25天前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
29 2
|
1月前
|
设计模式 Java 数据库连接
Java编程中的设计模式:单例模式的深度剖析
【10月更文挑战第41天】本文深入探讨了Java中广泛使用的单例设计模式,旨在通过简明扼要的语言和实际示例,帮助读者理解其核心原理和应用。文章将介绍单例模式的重要性、实现方式以及在实际应用中如何优雅地处理多线程问题。
36 4
|
1月前
|
设计模式 安全 Java
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
|
22天前
|
设计模式 安全 Java
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
|
1月前
|
设计模式 存储 数据库连接
PHP中的设计模式:单例模式的深入理解与应用
【10月更文挑战第22天】 在软件开发中,设计模式是解决特定问题的通用解决方案。本文将通过通俗易懂的语言和实例,深入探讨PHP中单例模式的概念、实现方法及其在实际开发中的应用,帮助读者更好地理解和运用这一重要的设计模式。
20 1
|
1月前
|
设计模式 安全 Java
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
Kotlin教程笔记(57) - 改良设计模式 - 单例模式
27 0
|
2月前
|
设计模式 存储 数据库连接
PHP中的设计模式:单例模式的深入解析与实践
在PHP开发中,设计模式是提高代码可维护性、扩展性和复用性的关键技术之一。本文将通过探讨单例模式,一种最常用的设计模式,来揭示其在PHP中的应用及优势。单例模式确保一个类仅有一个实例,并提供一个全局访问点。通过实际案例,我们将展示如何在PHP项目中有效实现单例模式,以及如何利用这一模式优化资源配置和管理。无论是PHP初学者还是经验丰富的开发者,都能从本文中获得有价值的见解和技巧,进而提升自己的编程实践。