js设计模式--创建型--单例模式

  创建型:单例模式

  保证一个类仅有一个实例,并提供一个访问它的全局访问点,这种模式叫做单例模式。

  单例模式的实现思路:

 1 // 首先先创建一个类,通过new关键字调用构造函数可以生成任意多得实例对象。
 2 class Single {
 3   show() {
 4     console.log("我是一个单列对象");
 5   }
 6 }
 7 const s1 = new Single();
 8 const s2 = new Single();
 9 
10 s1 === s2; // 返回false
11 // s1 和 s2 相互独立,各占内存空间。
12 
13 // 单例模式:不管创建多少次,都返回第一次创建得那个唯一实例。
14 class SingleCl {
15   show() {
16     console.log("我是单例对象");
17   }
18   static getInstance() {
19       // 先判断是否存在 instance 静态属性
20       if(!SingleCl.instance){
21         // 若没有创建,就先给 instance 静态属性添加实例
22         SingleCl.instance = new SingleCl();
23       }
24       // 如果唯一得实例存在,则直接返回
25       return SingleCl.instance;
26   }
27 }
28 const s3 = new SingleCl();
29 const s4 = new SingleCl();
30 s3 === s4  // 返回 true 不管调用多少次,都只返回一个实例

  单例模式的业务场景:

  Vuex 中的全局store 用于存储应用的所有状态,这个store正是 单例模式的典型应用。

  Vuex 如何确保 Store的唯一性

 Vue.use(Vuex)
 // 将store注入到Vue实例中
new Vue({ el: '#app', store })
// Vuex插件是一个对象,内部实现了一个 install 方法,会在安装的时候调用。把Store注入到 Vue中。 let Vue
// 这个Vue的作用和上面的 instance 作用一样 ... export function install (_Vue) { // 判断传入的Vue实例对象是否已经被install过Vuex插件(是否有了唯一的state) if (Vue && _Vue === Vue) { if (process.env.NODE_ENV !== 'production') { console.error( '[vuex] already installed. Vue.use(Vuex) should be called only once.' ) } return } // 若没有,则为这个Vue实例对象install一个唯一的Vuex Vue = _Vue // 将Vuex的初始化逻辑写进Vue的钩子函数里 applyMixin(Vue) }

  如果没有在 install 方法里面实现单例模式,如果一个应用不小心安装了多次,那么vue会重新注入一个新的 Store,中间的数据操作就都没有了。

 

  

  

posted @ 2021-04-12 11:33  SaBoo  阅读(176)  评论(0编辑  收藏  举报