JavaScript デザイン パターン シングルトン パターン
まえがき
JavaScript の開発プロセスでは、先駆者たちが実践から特定の問題に対する多くの解決策をまとめてきました。簡単に言うと、デザイン パターンとは、特定の場面での特定の問題に対する簡潔でエレガントな解決策です。
次の期間では、JavaScript で一般的なさまざまなデザイン パターンを記録します。もしかしたら、すでによく知っているかもしれませんし、日常的に使用しているかもしれませんが、その概念については特によく知らない、あるいは漠然とした概念しか持っていないかもしれません。このシリーズは間違いなくあなたに何らかの利益をもたらすと信じています。
これらの一般的なパターンを理解する前に、デフォルトで少なくとも次の内容をマスターしてください
これを
クロージャ- 高階関数
- プロトタイプとプロトタイプチェーン
- #それらを理解すると、パターンをより明確に理解するのに役立ちます。もちろん、この点に関して私が記録したことが役立つかもしれません
記事に欠陥や間違いがある場合は、こちらも読んでください。アドバイスをお願いします
さて、シングル ケース モードから始めましょう
コンセプト名前が示すように、インスタンスは 1 つだけです
定義: クラスのインスタンスが 1 つだけであることを確認し、それにアクセスするためのグローバル アクセス ポイントを提供しますこのような定義を見て、何か考えたことはありますか?グローバル変数の概念についてはどうですか?グローバル変数がシングルトン パターンの概念に準拠していることは否定できません。ただし、次の 2 つの理由により、通常はシングルトンとして使用しませんし、使用すべきではありません。
- #グローバルな名前付け汚染
- ##維持し、上書きされやすい
- ES6 より前は、通常、コンストラクターを使用してクラスをシミュレートしていましたが、現在では、 class キーワードを直接使用してクラスを作成することもできます。ただし、その本質はプロトタイプでもあります。
インスタンスが 1 つだけであることを確認し、グローバル アクセスを提供します
このコアを中心に、シングルトン モードの実装を基本的に理解しています
実装
基本バージョン
シングルトン パターンの定義に従って、次の方法で簡単に実装できます
var Singleton = function(name){ this.name = name } Singleton.instance = null // 初始化一个变量Singleton.getInstance = function(name) {// 判断这个变量是否已经被赋值,如果没有就使之为构造函数的实例化对象// 如果已经被赋值了就直接返回 if(!this.instance) { this.instance = new Singleton(name) } return this.instance } var a = Singleton.getInstance('Tadpole') var b = Singleton.getInstance('Amy') a === b // true
class Singleton { constructor(name){ this.name = name this.instance = null } // 提供一个接口对类进行实例化 static getInstance(name) { if(!this.instance) { this.instance = new Singleton(name) } return this.instance } }
- #結合が高すぎるため、機能的なビジネス コードを結合すると、後のメンテナンスに役立ちません
- Constructor
上記のメソッドに簡単な変更を加えてみましょう// 将变量直接挂在构造函数上面,最终将其返回
function Singleton(name) {
if(typeof Singleton.instance === 'object'){
return Singleton.instance
}
this.name = name
return Singleton.instance = this
}
// 正常创建实例
var a = new Singleton('Tadpole')
var b = new Singleton('Amy')
返される Single.instance タイプを決定すると、予期した結果が得られない可能性があります
結合が高すぎます
このメソッドは ES6 メソッドを通じて実装することもできます
// 将 constructor 改写为单例模式的构造器 class Singleton { constructor(name) { this.name = name if(!Singleton.instance) { Singleton.instance = this } return Singleton.instance } }
ログイン後にコピークロージャ
シングルトンの定義を通じてモードでは、インスタンスが 1 つだけ存在し、グローバル アクセスが提供できるようにする必要があります。そして、クロージャはそのようなニーズを確実に満たすことができます
var Singleton = (function () { var SingleClass = function () {}; var instance; return function () { if (!instance) { instance = new SingleClass() // 如果不存在 则new一个 } return instance; } })()
クロージャの特性により、変数は保存され、最終的に返され、グローバル アクセスが提供されます
同様に、上記のコードはまだ機能しません 問題を解決する
#このコードをよく観察して、コンストラクタ部分を外部に取り出したら、機能の分離は達成されるでしょうか?エージェントの実装
上記のコードを変更しますfunction Singleton(name) { this.name = name } var proxySingle = (function(){ var instance return function(name) { if(!instance) { instance = new Singleton(name) } return instance } })()
将创建函数的步骤从函数中提取出来,把负责管理单例的逻辑移到了代理类 proxySingle 中。这样做的目的就是将 Singleton 这个类变成一个普通的类,我们就可以在其中单独编写一些业务逻辑,达到了逻辑分离的效果
我们现在已经达到了逻辑分离的效果,并且也不 透明 了。但是,这个负责代理的类是否已经完全符合我们的要求呢,答案是否定的。设想一下,如果我们的构造函数有多个参数,我们是不是也应该在代理类中体现出来呢
那么,有没有更通用一些的实现方式呢
通用惰性单例
在前面的几个回合,我们已经基本完成了单例模式的创建。现在,我们需要寻求一种更通用的方式解决之前留下来的问题
试想一下,如果我们将函数作为一个参数呢
// 将函数作为一个参数传递 var Singleton = function(fn) { var instance return function() { // 通过apply的方式收集参数并执行传入的参数将结果返回 return instance || (instance = fn.apply(this, arguments)) } }
这种方式最大的优点就是相当于缓存了我们想要的结果,并且在我们需要的时候才去调用它,符合封装的单一职责
应用
前面有说过,所有的模式都是从实践中总结而来,下面就让我们来看看它在实际开发中都有哪些应用吧
通过单例模式的定义我们不难想出它在实际开发中的用途,比如:全局遮罩层
一个全局的遮罩层我们不可能每一次调用的时候都去创建它,最好的方式就是让它只创建一次,之后用一个变量将它保存起来,再次调用的时候直接返回结果即可
单例模式就很符合我们这样的需求
// 模拟一个遮罩层var createDiv = function () { var div = document.createElement('div') div.style.width = '100vw' div.style.height = '100vh' div.style.backgroundColor = 'red' document.body.appendChild(div) return div }// 创建出这个元素var createSingleLayer = Singleton(createDiv)document.getElementById('btn').onclick = function () { // 只有在调用的时候才展示 var divLayer = createSingleLayer() }
当然,在实际应用中还是有很多适用场景的,比如登录框,还有我们可能会使用到的 Vux 之类的状态管理工具,它们实际上都是契合单例模式的
后记
单例模式是一种简单而又实用的模式,通过创建对象和管理单例的两个方法,我们就可以创造出很多实用且优雅的应用。当然,它也有自身的缺点,比如只有一个实例~
合理使用才能发挥出它的最大威力
最后,推荐一波前端学习历程,感兴趣的小伙伴可以 点击这里 ,也可以扫描下方二维码关注我的微信公众号,查看往期更多内容,欢迎 star 关注
推荐教程:《JS教程》
以上がJavaScript デザイン パターン シングルトン パターンの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

WebSocket と JavaScript を使用してオンライン予約システムを実装する方法 今日のデジタル時代では、ますます多くの企業やサービスがオンライン予約機能を提供する必要があります。効率的かつリアルタイムのオンライン予約システムを実装することが重要です。この記事では、WebSocket と JavaScript を使用してオンライン予約システムを実装する方法と、具体的なコード例を紹介します。 1. WebSocket とは何ですか? WebSocket は、単一の TCP 接続における全二重方式です。

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

使用法: JavaScript では、insertBefore() メソッドを使用して、DOM ツリーに新しいノードを挿入します。このメソッドには、挿入される新しいノードと参照ノード (つまり、新しいノードが挿入されるノード) の 2 つのパラメータが必要です。

JavaScript は Web 開発で広く使用されているプログラミング言語であり、WebSocket はリアルタイム通信に使用されるネットワーク プロトコルです。 2 つの強力な機能を組み合わせることで、効率的なリアルタイム画像処理システムを構築できます。この記事では、JavaScript と WebSocket を使用してこのシステムを実装する方法と、具体的なコード例を紹介します。まず、リアルタイム画像処理システムの要件と目標を明確にする必要があります。リアルタイムの画像データを収集できるカメラ デバイスがあるとします。
