Maison >interface Web >js tutoriel >Compréhension approfondie de la série JavaScript (31) : Explication détaillée du modèle de proxy des compétences de design patterns_javascript
Présentation
L'agent, comme son nom l'indique, consiste à aider les autres à faire des choses. GoF définit le modèle d'agence comme suit :
Le mode proxy (Proxy) fournit un proxy pour d'autres objets pour contrôler l'accès à cet objet.
Le modèle proxy permet aux objets proxy de contrôler les références à des objets spécifiques. Un proxy peut être presque n'importe quel objet : un fichier, une ressource, un objet en mémoire ou quelque chose de difficile à copier.
Texte
Donnons un exemple simple. Si Dudu veut envoyer des roses à la fille au yaourt, mais qu'il ne connaît pas ses coordonnées ou qu'il est gêné, et veut confier à un oncle l'envoi de ces roses, alors l'oncle sera un agent (en fait c'est plutôt bien), vous pouvez déduire quelques fleurs pour votre belle-fille), alors comment faire ?
// C'est mec
var dudu = fonction (fille) {
This.girl = fille;
This.sendGift = fonction (cadeau) {
alert("Salut " girl.name ", dudu t'offre un cadeau : " gift);
>
};
//Oncle est un agent
var proxyTom = fonction (fille) {
This.girl = fille;
This.sendGift = fonction (cadeau) {
(new dudu(girl)).sendGift(gift); // Envoyer des fleurs à dudu
>
};
La méthode d'appel est très simple :
Combat pratique
Grâce au code ci-dessus, je pense que tout le monde est très clair sur le mode proxy. Pratiquons-le : nous avons une liste de lecture simple et devons afficher la musique de la vidéo sous le lien lorsque nous cliquons sur un seul lien (ou en sélectionnant tout). Bouton d'introduction et de lecture. Lorsque vous cliquez sur le bouton de lecture, la vidéo sera lue. La structure de la liste est la suivante :
.
Sélectionner tout/sélection inverse
Analysons-le d'abord. Tout d'abord, nous devons non seulement surveiller l'événement de clic d'une connexion, mais également surveiller l'événement de clic de « tout sélectionner/sélection inverse ». Ensuite, demander au serveur d'interroger les informations vidéo, d'assembler les informations. Informations HTML et affichez-les à la dernière position de l'élément li, l'effet est le suivant :
.Surveillez ensuite l'événement de clic de la connexion de lecture et commencez à jouer après avoir cliqué. L'effet est le suivant :
Bon, commençons, sans jQuery, personnalisons un sélecteur :
sql = sql.replace('%ID%', ids.join('","'));
sql = encodeURIComponent(sql);
url = sql '&' format '&' gestionnaire;
script.src = url;
document.body.appendChild(script);
>
};
Les objets proxy sont les suivants :
// Ajouter à la file d'attente dd à la file d'attente
This.ids.push(id);
this.callback = rappel;
This.context = contexte;
// Définir le délai d'attente
Si (!this.timeout) {
This.timeout = setTimeout(function () {
proxy.flush();
}, this.delay);
>
},
// Déclenchez la requête et appelez http.makeRequest
en utilisant la responsabilité proxy
flush : fonction () {
// proxy.handler est le rappel
lors de la demande de Yahoo
http.makeRequest(this.ids, 'proxy.handler'
);
// Après avoir demandé des données, exécutez la méthode proxy.handler (il existe un autre rappel défini)
//Effacer le délai d'attente et la file d'attente
This.timeout = null;
This.ids = [];
},
Gestionnaire : fonction (données) {
var je, max;
// Rappel pour une seule vidéo
Si (parseInt(data.query.count, 10) === 1) {
proxy.callback.call(proxy.context, data.query.results.Video);
revenir ;
>
// Rappels pour plusieurs vidéos
pour (i = 0, max = data.query.results.Video.length; i < max; i = 1) {
proxy.callback.call(proxy.context, data.query.results.Video[i]);
>
>
};
Le module de traitement vidéo a principalement trois sous-fonctions : obtenir des informations, afficher des informations et lire des vidéos :
if (data.query) {
data = data.query.results.Video;
>
id = data.id;
html = '';
html = '
' data.copyrightYear ', ' data.label '
';Album : ' data.Album.Release.title ', ' data.Album.Release.releaseYear '
';
>
html = '
si (!info) {
proxy.makeRequest(id, videos.updateList, vidéos); //执行代理职责,并传入videos.updateList回调函数
revenir ;
>
if (info.style.display === "aucun") {
info.style.display = '';
} autre {
info.style.display = 'none';
>
>
};
Nous pouvons maintenant traiter le code des événements de clic. Comme il existe de nombreuses connexions A, si chaque connexion lie un événement, il y aura évidemment des problèmes de performances, nous lions donc l'événement à l'élément
e = e || fenêtre.événement;
src = e.cible || e.srcElement;
// S'il n'est pas connecté, le processus ne continuera pas
Si (src.nodeName.toUpperCase() !== "A") {
revenir ;
>
//Arrête de bouillonner
If (typeof e.preventDefault === "function") {
e.preventDefault();
>
e.returnValue = false;
id = src.href.split('--')[1];
//Si vous cliquez sur le lien de lecture de la zone d'information vidéo qui a été produite, commencez la lecture
// Alors le retour ne continue pas
Si (src.className === "play") {
src.parentNode.innerHTML = videos.getPlayer(id);
revenir ;
>
src.parentNode.id = "v" id;
Videos.getInfo(id); // Il s'agit du code de traitement permettant d'afficher les informations vidéo lorsque vous cliquez pour la première fois
};
Les codes pour tout sélectionner et inverser la sélection sont similaires, nous ne les expliquerons donc pas :
var hrefs, i, max, id;
hrefs = $('vids').getElementsByTagName('a');
pour (i = 0, max = hrefs.length; i < max; i = 1) {
//Ignorer la connexion de jeu
Si (hrefs[i].className === "play") {
continuer ;
>
//Ignorer les éléments non sélectionnés
Si (!hrefs[i].parentNode.firstChild.checked) {
continuer ;
>
id = hrefs[i].href.split('--')[1];
hrefs[i].parentNode.id = "v" id;
vidéos.getInfo(id);
>
};
Résumé
Le mode proxy est généralement adapté aux situations suivantes :
1. Le proxy distant consiste à fournir une représentation locale d'un objet dans différents espaces d'adressage. Cela peut masquer le fait qu'un objet existe dans différents espaces d'adressage, tout comme la classe proxy dans le service Web.
2. Proxy virtuel, créez des objets coûteux selon vos besoins et utilisez-le pour stocker des objets réels dont l'instanciation prend beaucoup de temps. Par exemple, lorsque le navigateur effectue le rendu, le problème sera affiché en premier et l'image peut s'afficher lentement (c'est à dire). c'est-à-dire, via le proxy virtuel Au lieu de l'image réelle, l'agent virtuel enregistre le chemin et la taille de l'image réelle
.
3. Le proxy de sécurité est utilisé pour contrôler les autorisations lors de l'accès à des objets réels. Il est généralement utilisé pour les objets qui doivent avoir des autorisations d'accès différentes.
4. Guidage intelligent, ce n'est que lorsque l'objet réel est appelé que l'agent gère d'autres choses. Par exemple, dans le garbage collection en C#, lorsqu'un objet est utilisé, il y aura un décompte de références. Si l'objet n'est plus référencé, le GC peut le recycler.
Référence : "Modèle de conception Dahua"