Maison >interface Web >js tutoriel >Apprendre les modèles de conception JavaScript - compétences proxy pattern_javascript

Apprendre les modèles de conception JavaScript - compétences proxy pattern_javascript

WBOY
WBOYoriginal
2016-05-16 15:20:241116parcourir
  • Les célébrités sont représentées par des managers. Si vous demandez à une célébrité d'organiser une représentation commerciale, vous ne pouvez contacter que son agent. L'agent négociera les détails et la rémunération de la représentation commerciale, puis remettra le contrat à la célébrité pour qu'elle le signe.

1. Définition

Modèle de proxy : Fournissez un substitut ou un espace réservé pour un objet afin d'en contrôler l'accès.
Les agents sont divisés en : Agents de protection et agents virtuels
Agent de protection : est utilisé pour contrôler l'accès des objets avec différentes autorisations à l'objet cible. Il est difficile de juger qui a accédé à un objet en JavaScript, donc l'agent de protection est difficile. à mettre en œuvre.

2. Préchargement d'image (le scénario d'application d'agent virtuel le plus courant)

Le préchargement d'image est une technologie courante. Si vous définissez directement l'attribut src pour un nœud de balise img, la position de l'image sera souvent vide pendant un certain temps en raison d'une image trop grande ou d'un réseau médiocre. Une approche courante consiste à utiliser une image de chargement comme espace réservé à l'avance, puis à charger l'image de manière asynchrone. Une fois l'image chargée, remplissez-la dans le nœud img.
Principe de mise en œuvre :
Créez un objet Image : var a = new Image();
Définissez le src de l'objet Image : a.src = « xxx.gif »
Cela équivaut à mettre en cache une image pour le navigateur.

Vous pouvez vérifier si l'image est chargée via l'attribut complet de l'objet Image. Chaque objet Image a un attribut complet. Lorsque l'image est en cours de chargement, la valeur de l'attribut est fausse. Lorsque l'un des événements onload, onerror et onabort se produit, cela signifie que le processus de chargement de l'image est terminé. l'attribut complet est vrai.

(1) Implémentation sans proxy

var myImage = (function() {
  var imgNode = document.createElement("img");
  document.body.appendChild(imgNode);
  var img = new Image();

  img.onload = function() {
    imgNode.src = img.src;
  };

  return {
    setSrc: function(src) {
      imgNode.src = "./images/loading.gif";
      img.src = src;
    }
  }
})();

myImage.setSrc("./images/originImg.png");

(2) Implémentation du proxy

// 创建图片DOM
var myImage = (function() {
  var imgNode = document.createElement("img");
  document.body.appendChild(imgNode);

  return {
    setSrc: function(src) {
      imgNode.src = src;
    }
  };
})();

// 代理
var proxyImage = (function() {
  var img = new Image();

  img.onload = function() {
    myImage.setSrc(this.src);  // this指向img!img加载完成后,将img.src传递给myImage
  };

  return {
    setSrc: function(src) {
      myImage.setSrc("./images/loading.gif");   // loading
      img.src = src;
    }
  };
})();

proxyImage.setSrc("./images/originImg.png");

Les avantages de l'utilisation du mode proxy : rendre chaque fonction unique et réaliser le « principe de responsabilité unique » de la conception d'objets !

3. Synchronisation des fichiers

Supposons que nous effectuions une fonction de synchronisation de fichiers. Lorsque la case est cochée, son fichier correspondant sera synchronisé avec un autre serveur.

<body>
    <input type="checkbox" id="1" />文件1
    <input type="checkbox" id="2" />文件2
    <input type="checkbox" id="3" />文件3
    <input type="checkbox" id="4" />文件4
    <input type="checkbox" id="5" />文件5
    <input type="checkbox" id="6" />文件6
  </body>

Il est évidemment déraisonnable de synchroniser une seule fois sans cocher une case. Parce que dans le développement Web, la plus grande surcharge concerne les requêtes réseau.
Solution : Utilisez une fonction proxy pour collecter les demandes dans un délai donné, puis envoyez-les au serveur en une seule fois.

var synchronousFile = function(id) {
  console.log("开始同步文件,id为:" + id);
};

var proxySynchonousFile = (function() {
  var cache = [],   // 保存本次需要同步文件的id
    timer;     // 定时器

  return function(id) {
    cache.push(id);
    if(timer) { 
      // 不要覆盖已经启动的定时
      return;
    }

    timer = setTimeout(function(){
      synchronousFile(cache.join(","));
      clearTimeout(timer);
      timer = null;
      cache.length = 0;  // 清空缓存
    }, 2000);
  }
})();

var checkboxs = document.getElementsByTagName("input");

for(var i = 0, c; c = checkboxs[i]; i++) {
  c.onclick = function() {
    if(this.checked === true) {
      proxySynchonousFile(this.id);
    }
  }
}

4. Proxy de mise en cache – calcul du produit (la séquence est exactement la même)

var mult = function() {
  var result = 1;
  for(var i = 0, l = arguments.length; i < l; i++) {
    result= result * arguments[i];
  }
  return result;
};

var proxyMult = (function() {
  var cache = {};   // {"1,2,3": 6}
  return function() {
    var args = Array.prototype.join.call(arguments, ",");
    if(args in cache) {
      return cache[args];
    }
    return cache[args] = mult.apply(this, arguments);
  }
})();

console.log(proxyMult(1, 2, 3));

// 改造:

var proxyFactory = function(fn) {
  var cache = {};
  return function() {
    var args = Array.prototype.join.call(arguments, ",");
    if(args in cache) {
      return cache[args];
    }
    return cache[args] = fn.apply(this, arguments);
  }  
};

console.log(proxyFactory(mult)(1, 2, 3));

J'espère que cet article sera utile à tous ceux qui apprennent la programmation JavaScript.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn