(二)js前端开发中设计模式之单例模式
创始人
2025-01-07 03:35:29
0

单例模式

保证一个类仅有一个实例,并提供一个访问它的全局访问点。
利弊分析

  • 优点:

    • 单例模式可以保证内存中只有一个对象,减少了内存的开销。
    • 可以避免对资源的多重占用。
    • 方便测试,可以通过接口来控制类的实例化。
    • 避免对资源的多重占用。
  • 缺点:

    • 单例模式一般没有接口,扩展比较困难。
    • 单点访问,可能会导致模块的耦合。
  • 基本的单例模式,就是对象字面量

const SingleTon = {   name:"tom",   age"26",   say(){     console.log("hello")   },   eat(){     console.log("rice")   } }  //访问单例 SingleTon.gender = '男' SingleTon.say() 

划分命名空间

var GianCrop = {}; GianCrop.common = {}; GianCrop.errorCodes = {}; GianCrop.pageHandler = {}; 

使用私有成员

  • 方式一:约定
GianCrop.dataParse = {   //约定私有成员以_开头   _method1() {},   _method2() {},   _method3() {}   //约定公共成员不以_开头   method1() {},   method2() {},   method3() {} };  
  • 方式二:闭包
// MyNameSpce.SingleTon = {} // 闭包单例模式 let MyNameSpce = {}; MyNameSpce.SingleTon = (function () {   return {     name: "tom",     age: 26,     say() {       console.log("hello");     },     eat() {       console.log("rice");     },   }; })();  const name = MyNameSpce.SingleTon.name; console.log("🚀 ~ name:", name); 

增加私有成员

let MyNameSpce = {}; MyNameSpce.SingleTon = (function () {   let isFlag = true;   let count = 30;   function getCount() {     return count;   }   return {     name: "tom",     age: 26,     say() {       console.log("hello");     },     eat() {       console.log("rice");     },     getFlag() {       return isFlag;     },     getCount,   }; })();  const { name, getFlag, getCount } = MyNameSpce.SingleTon; console.log("🚀 ~ name:", name); console.log("🚀 ~ getFlag:", getFlag()); console.log("🚀 ~ getCount:", getCount());  /**  * 🚀 ~ name: tom demo05.js:46 🚀 ~ getFlag: true demo05.js:47 🚀 ~ getCount: 30  */ 

惰性单例模式

let MyNameSpce1 = {}; MyNameSpce1.SingleTon = (function () {   let singleTon = null;   function init() {     let isFlag = true;     let count = 30;     function getCount() {       return count;     }     console.log("init-----------");     return {       name: "tom",       age: 26,       say() {         console.log("hello");       },       eat() {         console.log("rice");       },       getFlag() {         return isFlag;       },       getCount,     };   }   return {     getInstance() {       if (!singleTon) {         singleTon = init();       }       return singleTon;     },   }; })();  const demo = MyNameSpce1.SingleTon.getInstance(); const demo2 = MyNameSpce1.SingleTon.getInstance();  console.log(demo.name); console.log(demo2.name);  //调用了两次实例,但是只初始化了一次  /**  *  * 🚀 ~ name: tom  * 🚀 ~ getFlag: true    🚀 ~ getCount: 30    init-----------    tom    tom  */ 

分支

var SimpleXhrFactory = (function () {   const standard = {     createXhrObjec() {       return new XMLHttpRequest();     },   };   const activeXNew = {     createXhrObject() {       return new ActiveXObject("Microsoft.XMLHTTP");     },   };   const activeOld = {     createXhrObject() {       return new ActiveXObject("Msxml2.XMLHTTP");     },   };   var testObject;   try {     testObject = standard.createXhrObject();     return standard;   } catch (error) {     try {       testObject = activeXNew.createXhrObject();       return activeXNew;     } catch (error) {       try {         testObject = activeOld.createXhrObject();         return activeOld;       } catch (error) {         throw new Error("can't create xhr object");       }     }   } })(); 

相关内容

热门资讯

绝活儿辅助!广西老友玩老是输怎... 绝活儿辅助!广西老友玩老是输怎么办(辅助挂)都是真的有辅助app(讲解有挂)在进入广西老友玩老是输怎...
法门辅助!福建13水插件(辅助... 法门辅助!福建13水插件(辅助挂)一贯是有辅助技巧(有挂技术)1、许多玩家不知道福建13水插件辅助怎...
办法辅助!潮友会app下载官方... 办法辅助!潮友会app下载官方辅助器(辅助挂)真是真的是有辅助app(有挂教程)该软件可以轻松地帮助...
妙招辅助!邯郸胡乐挂辅助(辅助... 妙招辅助!邯郸胡乐挂辅助(辅助挂)好像存在有辅助插件(有挂方略)1、上手简单,内置详细流程视频教学,...
教程书辅助!乐酷辅助(辅助挂)... 教程书辅助!乐酷辅助(辅助挂)其实存在有辅助脚本(有挂细节)乐酷辅助能透视中分为三种模型:乐酷辅助模...
学习辅助!决战卡五星辅助(辅助... 学习辅助!决战卡五星辅助(辅助挂)本来真的是有辅助软件(有人有挂)学习辅助!决战卡五星辅助(辅助挂)...
绝活辅助!边锋嘉兴麻将辅助器(... 绝活辅助!边锋嘉兴麻将辅助器(辅助挂)真是真的有辅助神器(新版有挂)1、边锋嘉兴麻将辅助器公共底牌简...
举措辅助!枫叶辅助器(辅助挂)... 举措辅助!枫叶辅助器(辅助挂)本来存在有辅助技巧(竟然有挂)1、下载好枫叶辅助器正确养号方法之后点击...
讲义辅助!点我达辅助(辅助挂)... 讲义辅助!点我达辅助(辅助挂)一直存在有辅助技巧(有人有挂)1、点我达辅助辅助器安装包、点我达辅助辅...
模块辅助!威信茶馆有挂的吗(辅... 模块辅助!威信茶馆有挂的吗(辅助挂)一直真的是有辅助脚本(揭秘有挂)1、玩家可以在威信茶馆有挂的吗线...