Maison >interface Web >js tutoriel >Introduction au modèle Singleton des modèles de conception JavaScript
Cet article présente principalement le mode singleton du design pattern JavaScript. Le mode singleton est un objet qui a été instancié en accès statique. Cet objet n'est accessible que via une entrée unique, soit déjà instanciée, soit à instancier. de transformation, les amis dans le besoin peuvent s'y référer.
Description du mode monobloc
1. Description : Le mode monobloc est un objet qui a été instancié en accès statique. , cet objet n'est accessible que via une entrée unique, un objet qui a été instancié ou qui doit être instancié ; les langages orientés objettels que Java, .Net C# et d'autres langages dynamiques côté serveur peut garantir que les opérations de classe se déroulent sans problème et éviter le parallélisme. Les opérations peuvent provoquer une confusion des données
2.Avantages du mode singleton :
1) Réduire les nouvelles opérations pour éviter d'accélérer les opérations de mémoire fréquentes et d'occuper celles-ci ; mémoire;
2) , Minimiser la surcharge des objets dans les grands systèmes
3) Comme mentionné ci-dessus, il peut garantir que certains types d'opérations sont effectués dans un ordre précis pour éviter les anomalies de données causées par un traitement parallèle ; 🎜>
Code source de l'instance
var Singleton = { instance: null, MailSender: function() { var self = this; self.to = ''; self.title = ''; self.content = ''; self.send = function() { //send body } }, getInstance : function() { if (this.instance == null) { this.instance = new Singleton.MailSender(); } return this.instance; } }
Utilisation :
var mail = Singleton.getInstance(); mail.to = 'toname#mail.com'; mail.title = '单件模式发送'; mail.content = '发送内容'; mail.send();Lorsque certains frameworks globaux, tels que les frameworks d'interface utilisateur riches comme DWZ, créent un Singleton global, Singleton.instance a une valeur, et il n'est pas nécessaire de le créer à nouveau Bien sûr ; , si c'est écrit comme ça, Ce sera plus clair, et il sera combiné avec le langage côté serveur :
Singleton.getInstance().to = 'toname#mail.com'; Singleton.getInstance().title = '单件模式发送'; Singleton.getInstance().content = '发送内容'; Singleton.getInstance().send();
Autres explications pratiques
Où le mode singleton est-il plus utile ? Par exemple, lorsqu'il existe un fichier de configuration unifié sur le serveur d'exploitation, comme des opérations simultanées à grande échelle et la nécessité de prêter attention à la situation du premier arrivé, premier servi, comme les enregistrements du processus d'opération des échanges, etc. , vous pouvez utiliser le mode monobloc pour fonctionner ; De plus : Méthode en mode unique : 1 La méthode ci-dessus est appelée méthode paresseuse2. méthode :var Singleton = { instance : new Singleton.MailSender(), MailSender : function() { var self = this; self.to = ''; self.title = ''; self.content = ''; self.send = function() { //send body } }, getInstance : function() { return this.instance; } }La méthode d'utilisation est la même ;Utilisez la méthode de fermeture pour créer le mode singleton et masquer l'objet d'instanceCode :
var Singleton = (function() { var instance = null; function MailSender() { this.to = ''; this.title = ''; this.content = ''; } MailSender.prototype.send = function() { //send body } return { getInstance : function() { if (instance == null) { instance = new MailSender(); } return instance; } } })();2. Utilisation :
Ce qui précède représente l'intégralité du contenu de ce chapitre. Pour plus de didacticiels connexes, veuillez visiter le
//一样用法 var mail = Singleton.getInstance(); mail.to = 'toname#mail.com'; mail.title = '闭包式 单件模式发送'; mail.content = '发送内容'; mail.send();Tutoriel vidéo JavaScript