DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> js單例模式的兩種方案
js單例模式的兩種方案
編輯:關於JavaScript     

方案一:利用閉包的兩個作用,可以變通地讀到內部的變量,二是可以讓這些變量始終在內存中。

復制代碼 代碼如下:
//方案一
    var SingletonTester = (function () {
        //單例方法
        function Singleton(args) {
            var args = args || {};
            this.name = 'SingletonTester'; //方法對外的屬性,另外一種方式就是返回對象
            this.pointX = args.pointX || 6;
            this.pointY = args.pointY || 10;
        }

        //單例實例
        var instance;

        //返回對象
        return {
            name: 'SingletonTester',

            getInstance: function (args) {
                if (instance === undefined) {
                    instance = new Singleton(args);
                }
                return instance;
            }
        };
    })(); //直接執行該方法

    //測試
    var test = SingletonTester.getInstance({ pointX: 5 });
    console.log(test.pointX);

方案二: 

復制代碼 代碼如下:
//方案二
  function Universe() {
      // 判斷是否存在實例
      if (typeof Universe.instance === 'object') {
          return Universe.instance;
      }

      // 其它內容
      this.start_time = 0;
      this.bang = "Big";

      // 緩存
      Universe.instance = this;

      // 隱式返回this
  }

  // 測試
  var uni = new Universe();
  var uni2 = new Universe();
  console.log(uni === uni2); // true

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved