學(xué)習(xí)JavaScript設(shè)計模式之單例模式
一、定義
保證一個類僅有一個實(shí)例,并提供一個訪問它的全局訪問點(diǎn)。
當(dāng)單擊登陸按鈕,頁面中出現(xiàn)一個登陸浮窗,這個登陸浮窗是唯一的,無論單擊多少次登陸按鈕,這個浮窗都只會被創(chuàng)建一次,那么這個登陸浮窗就適合用單例模式來創(chuàng)建。
二、實(shí)現(xiàn)原理
要實(shí)現(xiàn)單例并不復(fù)雜,使用一個變量來標(biāo)志當(dāng)前是否已經(jīng)為某個類創(chuàng)建過對象,如果是,則在下一次獲取該類的實(shí)例時,直接返回之前創(chuàng)建的對象。
三、假單例
全局變量不是單例模式,但在JavaScript開發(fā)中,我們經(jīng)常會把全局變量當(dāng)成單例來使用。
var a = {};
降低全局變量帶來的命名污染
(1)使用命名空間
var namespace1 = { a: function(){}, b: 2 }
(2)使用閉包封裝私有變量
var user = (function() { var _name = 'lee', _age = '25'; return { getUserInfo: function() { return _name + ":" + _age; } }; })();
四、惰性單例:在需要的時候才能創(chuàng)建對象實(shí)例
var getSingle = function(fn) { var result; return function() { return result || (result = fn.apply(this, arguments)); }; }; // 測試 function testSingle(){} getSingle(testSingle)() === getSingle(testSingle)(); // true
五、補(bǔ)充:
(1)懶加載
var lazyload = function() { console.log(1); lazyload = function() { console.log(2); } return lazyload(); } lazyload();
(2)預(yù)加載
var preload = (function() { console.log(1); preload = function() { console.log(2); }; return preload; })(); preload();
希望本文所述對大家學(xué)習(xí)javascript程序設(shè)計有所幫助。
- JavaScript設(shè)計模式---單例模式詳解【四種基本形式】
- JS 設(shè)計模式之:單例模式定義與實(shí)現(xiàn)方法淺析
- javascript設(shè)計模式 – 單例模式原理與應(yīng)用實(shí)例分析
- 《javascript設(shè)計模式》學(xué)習(xí)筆記三:Javascript面向?qū)ο蟪绦蛟O(shè)計單例模式原理與實(shí)現(xiàn)方法分析
- js設(shè)計模式之單例模式原理與用法詳解
- JavaScript設(shè)計模式之單例模式原理與用法實(shí)例分析
- JavaScript設(shè)計模式之單例模式簡單實(shí)例教程
- JS基于設(shè)計模式中的單例模式(Singleton)實(shí)現(xiàn)封裝對數(shù)據(jù)增刪改查功能
- JS設(shè)計模式之單例模式(一)
- NodeJS設(shè)計模式總結(jié)【單例模式,適配器模式,裝飾模式,觀察者模式】
- JavaScript設(shè)計模式之單例模式實(shí)例
- JavaScript中的設(shè)計模式 單例模式
相關(guān)文章
TopList標(biāo)簽和JavaScript結(jié)合兩例
TopList標(biāo)簽和JavaScript結(jié)合兩例...2007-08-08javascript 實(shí)現(xiàn)自由落體的方塊效果
這其實(shí)是一個很簡單的實(shí)現(xiàn),create一個新的div元素,然后append到文檔的body上,經(jīng)過一定時間的延遲,做自由落體運(yùn)動,著地后fade消失。 不多說,直接上代碼。2010-01-01JavaScript實(shí)現(xiàn)兩個數(shù)組的交集
這篇文章主要介紹了JavaScript實(shí)現(xiàn)兩個數(shù)組的交集,給定兩個數(shù)組???nums1???和??nums2??返回它們的交集,輸出結(jié)果中的每個元素一定是唯一的,下文詳細(xì)介紹,需要的小伙伴可以參考一下2022-03-03js獲取元素到文檔區(qū)域document的(橫向、縱向)坐標(biāo)的兩種方法
獲取頁面中元素到文檔區(qū)域document的橫向、縱向坐標(biāo),在js控制元素運(yùn)動的過程中,對于頁面元素坐標(biāo)位置的獲取是經(jīng)常用到的,這里主要總結(jié)下兩種方法2013-05-05JS調(diào)用打印方法設(shè)置頁眉頁腳的實(shí)例
一個網(wǎng)頁打印相關(guān)功能的擴(kuò)展演示特效,在實(shí)現(xiàn)了打印功能外,還實(shí)現(xiàn)了打印預(yù)覽、打印前的頁眉頁腳設(shè)置,直接打印等功能,以前對JS打印前設(shè)置頁腳見的不多,所以這一個也算是挺有價值的,希望閑暇時參閱2013-05-05JavaScript基于面向?qū)ο髮?shí)現(xiàn)的無縫滾動輪播示例
這篇文章主要介紹了JavaScript基于面向?qū)ο髮?shí)現(xiàn)的無縫滾動輪播,結(jié)合實(shí)例形式分析了JavaScript面向?qū)ο髮?shí)現(xiàn)的無縫滾動輪播相關(guān)對象定義、初始化及功能實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-01-01