javascript - 单例模式的简单 JS 示例不起作用

标签 javascript jquery design-patterns singleton

我做了一个简单的单例模式示例,但在这两种情况下它都给出了空白对象。请有人帮忙吗?

var a = ( function(){
	
  var instance = {};

  function init() {
     return {
      name: "rosy",
      age: 29,
      printName: function(){
        console.log(this.name)
      }
    }
  }

  return {
    getInstance: function(){
      if(!instance) {instance = init();}
      return instance;
    }
  }
})();

console.log(a.getInstance());
console.log(a.getInstance());

最佳答案

正如我在评论中所说,问题在于 instance 被初始化为 {},这是事实,因此 !instance 将永远不会是真的。

只有一个实例变量是为对匿名函数的一个调用而创建的。这就是拥有它的全部意义,它跟踪单例。因此用一个假值初始化它(或者保留默认的undefined,这是假值):

var a = ( function(){
	
  var instance = null;

  function init() {
     return {
      name: "rosy",
      age: 29,
      printName: function(){
        console.log(this.name)
      }
    }
  }

  return {
    getInstance: function(){
      if(!instance) {instance = init();}
      return instance;
    }
  }
})();

const first = a.getInstance();
console.log(first);
const second = a.getInstance();
console.log(second);
console.log(first === second); // true
.as-console-wrapper {
    max-height: 100% !important;
}

也就是说,如果您想要延迟初始化,则只需要所有这些复杂性。否则,只需创建对象:

var a = {
    instance = {
      name: "rosy",
      age: 29,
      printName: function(){
        console.log(this.name)
      }
    }
};

那么a.instance就是单例。如果您希望它不可写:

var a = Object.defineProperty({}, "instance", {
    value: {
      name: "rosy",
      age: 29,
      printName: function(){
        console.log(this.name)
      }
    }
});

(这也将是不可枚举的。如果您希望它可枚举,请添加 enumerable: true。)

或者只是:

var instance: {
  name: "rosy",
    age: 29,
    printName: function(){
      console.log(this.name)
    }
};

如果您希望它是只读的,请在任何现代环境中使用 const:

const instance: {
  name: "rosy",
    age: 29,
    printName: function(){
      console.log(this.name)
    }
};
<小时/>

在上述所有中,请记住,尽管您可能有一个单例,并且实例属性/常量可能是只读的,但与对象本身无关是不可变的。可以添加、删除、更改属性等。要防止出现这种情况,请使用 Object.freeze .

关于javascript - 单例模式的简单 JS 示例不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59553410/

相关文章:

javascript - 固定的动态侧边栏导航菜单?

javascript - 如何使用函数动态分配 d3.forceRadial 的中心?

javascript - Ajax 删除请求返回 200 但引发错误

用于解析标签的 php preg_match 模式

java - 使用接口(interface)或抽象的设计模式

c# - 我什么时候可以在 native foreach 循环上使用 List<T>.ForEach?

javascript - 如何让点击div1时显示image1,点击div2时image2替换image1?

javascript - 过滤 Axios 响应

javascript - 使用 Javascript window.confirm 停止 window.event?

javascript - 如何隐藏功能