(二)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");       }     }   } })(); 

相关内容

热门资讯

辅助了解!人人燕赵辅助(辅助)... 您好,人人燕赵辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩家在...
辅助了解!情怀莆仙吹牛脚本(辅... 辅助了解!情怀莆仙吹牛脚本(辅助)捉住捣蛋鸡都是存在有辅助挂(哔哩哔哩)1、超多福利:超高返利,海量...
详细了解!新518互游插件(辅... 详细了解!新518互游插件(辅助)白金岛歪胡子竟然是真的辅助下载(哔哩哔哩)运新518互游插件辅助工...
教你了解!宝宝吃吃吃外g挂(辅... 教你了解!宝宝吃吃吃外g挂(辅助)开心娱乐一直真的是有辅助软件(哔哩哔哩)1、许多玩家不知道宝宝吃吃...
分享了解!微信开心泉州辅助(辅... 分享了解!微信开心泉州辅助(辅助)怀远麻将本来是真的辅助器(哔哩哔哩)1、实时微信开心泉州辅助透视辅...
关于了解!冰球突破辅助软件(辅... 关于了解!冰球突破辅助软件(辅助)和和嫩江麻将果然是有辅助神器(哔哩哔哩)1.冰球突破辅助软件 选牌...
科普了解!川娱竞技血战辅助器(... 科普了解!川娱竞技血战辅助器(辅助)中至鹰潭麻将原来是真的辅助平台(哔哩哔哩)1、玩家可以在川娱竞技...
推荐了解!微乐小程序辅助(辅助... 推荐了解!微乐小程序辅助(辅助)聚游广东麻将本来有挂辅助软件(哔哩哔哩)1、不需要AI权限,帮助你快...
必备了解!皮皮游戏辅助器(辅助... 必备了解!皮皮游戏辅助器(辅助)盛世2果然有挂辅助安装(哔哩哔哩);1、玩家可以在皮皮游戏辅助器线上...
透视了解!三哥玩透视辅助(辅助... 透视了解!三哥玩透视辅助(辅助)米乐互娱竟然是真的辅助脚本(哔哩哔哩)进入游戏-大厅左侧-新手福利-...