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

相关内容

热门资讯

黑科技脚本(poker有没有外... 您好,poker有没有外挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很...
黑科技教学(WePoKe)fi... 黑科技教学(WePoKe)fishpoker俱乐部有挂吗(ai代打)总是是有挂(2023已更新)(哔...
黑科技辅助挂(wepokeai... wepoke是机器发牌吗赢率提升策略‌;黑科技辅助挂(wepokeai代打)wepoke是机器发牌吗...
科技介绍!德扑之星软件透明有人... 科技介绍!德扑之星软件透明有人买(黑科技ai)wpk教程(2025已更新)(哔哩哔哩);致您一封信;...
黑科技软件(德扑ai自定义设置... 黑科技软件(德扑ai自定义设置数据)外挂透明挂辅助黑科技(透视)原来存在有挂(有挂教学)-哔哩哔哩1...
黑科技app(WePoKe)来... 黑科技app(WePoKe)来玩德州辅助器(透明挂黑科技)其实是有挂(2024已更新)(哔哩哔哩)1...
黑科技有挂(wepokeai代... 黑科技有挂(wepokeai代打)wepower微扑克外挂(wEpoke)一贯有挂(有挂存在)-哔哩...
玩家必看科普!!wpk脚本(智... 1、玩家必看科普!!wpk脚本(智能ai)黑科技教程(2024已更新)(哔哩哔哩);该软件可以轻松地...
黑科技私人局(德州ai辅助神器... 黑科技私人局(德州ai辅助神器app)外挂透明挂辅助软件(透视)一贯存在有挂(有挂方针)-哔哩哔哩所...
黑科技软件(WePoKe)微扑... 黑科技软件(WePoKe)微扑克辅助安卓版本(智能ai)其实存在有挂(2021已更新)(哔哩哔哩)1...