专栏首页FinGet前端之路JavaScript设计模式之单例模式

JavaScript设计模式之单例模式

单例模式

系统中被唯一使用,一个类只有一个实例。实现方法一般是先判断实例是否存在,如果存在就返回,不存在就创建再返回。 在JavaScript里,单例作为空间提供者,从全局命名空间里提供一个唯一的访问点来访问该对象。

模式作用:

  • 模块间通信
  • 系统中某个类的对象只能存在一个
  • 保护自己的属性和方法

注意事项:

  • 注意this的使用
  • 闭包容易造成内存泄漏,不需要的赶快干掉
  • 注意new的成本

代码示例

java中的单例模式

java请类型可以私有化,外部new就会报错。

JavaScript中的单例模式

class SingleObject {
  login() {
	console.log('login')
  }
}
// 利用闭包实现了私有变量
SingleObject.getInstance = (fucntion () {
  let instance
  return function () {
	if (!instance) {
	  instance = new SingleObject()
	}
	return instance
  }
})()

let obj1 = SingleObject.getInstance()
obj1.login()
let obj2 = SingleObject.getInstance()
obj2.login()
// 两者是否相等
console.log(obj1 === obj2)


// js弱类型,没有私有方法,使用者还是可以直接new 一个 SingleObject,也会有 login方法
console.log('------------分割线------------')
let obj3 = new SingleObject()
obj3.login()
console.log('obj1===obj3',obj1 === obj3) // false 不是单例

最简单的单例模式,就是对象。在 JavaScript 中 定义一个对象(Object),那么它的属性,就只能通过它自己调用。就算两个不同的对象,有相同的属性名,也不能相互调用,保护了自己属性。

登录框 单例

class LoginForm {
  constructor() {
    this.state = 'hide'
  }
  show() {
    if (this.state === 'show') {
      alert('已经显示')
      return
    }
    this.state = 'show'
    console.log('登录框已显示')
  }
  hide() {
    if (this.state === 'hide') {
      alert('已经隐藏')
      return
    }
    this.state = 'hide'
    console.log('登录框已隐藏')
  }
}
LoginForm.getInstance = (function () {
  let instance
  return function () {
    if (!instance) {
      instance = new LoginForm();
    }
    return instance
  }
})()

// 一个页面中调用登录框
let login1 = LoginForm.getInstance()
login1.show()
// login1.hide()

// 另一个页面中调用登录框
let login2 = LoginForm.getInstance()
login2.show()

// 两者是否相等
console.log('login1 === login2', login1 === login2)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaScript数据结构与算法-Array

    例如:1 ^ 1 = 0 、 2 ^ 2 = 0、 0 ^ 1 = 1 、1 ^ 1 ^ 2 ^ 3 ^ 2 ^ 4 ^ 3 = 4

    FinGet
  • JavaScript从初级往高级走系列————异步

    上面这个例子中,当执行了alert(1),如果用户不点击确定按钮,console.log(2)是不会执行的。

    FinGet
  • 原生——ajax

    什么是Ajax?(前后端数据交互) Asynchronous JavaScript and XML(异步JavaScript和XML)

    FinGet
  • ES6

    在cmd命令窗口初始化项目-y代表全部默认同意,就不用一次次按回车了。命令执行完成后,会在项目根目录下生产package.json文件。

    楠楠
  • 【学习笔记】ES6新的语法

    无道
  • JavaScript正则表达式(Regular Expression):RegExp对象

    第一部分:新建正则表达式 JavaScript中正则表达式是参照Perl 5(一门历史很悠久的语言,现在tiobe编程语言排行依然在10名左右)建立的。 新建正...

    用户1149564
  • for 循环 和 Array 数组对象

    - forEach 不支持 return 和 break,一定会把所有数据遍历完毕

    柳醉梦声
  • ES6——数组

    一个类数组对象必须含有 length 属性,且元素属性名必须是数值或者可转换为数值的字符。

    羊羽shine
  • Node 简单总结

    事件循环时典型的生产者/消费者模型,异步io,网络请求是生产者,源源不断等为node提供不同的事件,这次事件被传递导对应的观察者那里,事件循环则从观察者那里取出...

    mafeifan
  • RxSwift 系列(九) -- 那些难以理解的概念

    Scott_Mr

扫码关注云+社区

领取腾讯云代金券