Maison > interface Web > js tutoriel > Explication détaillée sur la mise en œuvre de la fonction de fusion d'objets

Explication détaillée sur la mise en œuvre de la fonction de fusion d'objets

小云云
Libérer: 2018-01-26 11:54:09
original
1184 Les gens l'ont consulté

Cet article vous apporte principalement un exemple d'implémentation basé sur la fonction de fusion d'objets. L'éditeur le trouve plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence pour tout le monde. Suivons l'éditeur pour y jeter un œil, j'espère que cela pourra aider tout le monde.

Préface

$.extend() dans jQuery est une fonction outil souvent utilisée, principalement utilisée pour fusionner des paramètres (objets). L'utilisation spécifique ne sera pas décrite ici. Vous pouvez transmettre Le paramètre contrôle si une copie complète est utilisée pendant le processus de fusion ; la nouvelle méthode Object.assign() dans ES2015 peut également réaliser la fusion d'objets, mais une copie superficielle est utilisée pendant le processus de fusion ; le code source de la méthode extend de jQuery. Fusionnez vos propres objets, c'est-à-dire copiez les propriétés de plusieurs objets dans l'objet cible. S'il existe les mêmes propriétés, les objets ultérieurs écraseront les précédents.

Une méthode de copie superficielle pour réaliser la fusion d'objets

Un article de blog précédent a spécifiquement présenté les copies profondes et superficielles d'objets et de tableaux. Si vous ne comprenez pas, veuillez lire ici. Regardons d'abord l'implémentation puis expliquons

function extend() { //extend 浅拷贝实现
  var name,options,copy,
   length = arguments.length,
   i = 1,
   target = arguments[0] || {}; //取目标对象
  
 if(['object','function'].indexOf(typeof target) < 0){
  target = {};
  }
 

  for(;i<length;i++){

  options = arguments[i]

  if(options != null){ //排除空参数的情况 extend({},,)

   for(name in options){ //遍历对象 赋值

   copy = options[name];

   if (copy !== undefined) {
    target[name] = copy;
   }
   }
  }
  }

  return target 
 }

 //测试数据 
 var test1 = {
  a : 1,
  b : {
  c : 2,
  d : 3
  },
  e : [1,'a']
 },
 test2 = {
  b : {
  c : 4,
  d : 5,
  f : 6
  },
  e : [1,'a'],
  g : 7
 }

 var test = extend({},test1,test2);
 console.log(test.b.d); //5

 test2.b.d = 'x'; //修改test2
 console.log(test.b.d); // 'x' test随之修改
Copier après la connexion

L'idée est la suivante :

1 Par défaut, le premier paramètre est pris comme objet cible. Le premier paramètre n'est pas un type de données d'objet, attribuez une valeur. Est un objet vide

2. Parcourez les paramètres restants (objet source) et copiez les propriétés de l'objet source dans l'objet cible.

3. Renvoyez l'objet cible comme résultat fusionné

Dans la deuxième étape, les valeurs d'attribut de l'objet source ne sont pas jugées. Toutes sont attribuées à l'aide de '=', donc quand. de l'objet source Lorsque la valeur d'attribut est un attribut d'objet, seule la valeur de référence est copiée, qui est une copie superficielle. D'après les résultats du test, on peut voir que les valeurs d'attribut de l'attribut b de test et test2 utilisent le. même objet et s’influenceront mutuellement. Après avoir su cela, vous devriez avoir une idée sur la façon de mettre en œuvre la copie approfondie lors de la fusion.

Pour implémenter la fusion d'objets via la copie profonde

Il est nécessaire de déterminer le type de valeur lors de la copie de la valeur de l'attribut de l'objet source. S'il s'agit d'un type de données d'objet, la fonction d'extension est appelée. récursivement. Ensuite, vous pouvez pratiquer la méthode de copie profonde de fusion d'objets, et la mise en œuvre est la suivante :

function extend() { //extend 深拷贝实现
  var name,options,src,copy,
   deep = false, //是否深拷贝 默认为false
   length = arguments.length,
   i = 1,
   target = arguments[0] || {};

  //如果第一个参数为boolean类型,赋值给deep
  if(typeof target == 'boolean'){
  deep = arguments[0];
  target = arguments[i] || {}; //目标对象顺延
  i++;
  }

  //如果target不是对象数据类型的话 target赋值为 {}
  if(['object','function'].indexOf(typeof target) < 0){
  target = {};
  }

  for(;i<length;i++){

  options = arguments[i];

  if(options != null){

   for(name in options){

   copy = options[name];
   src = target[name];

   if(target === copy){ //避免重复循环
    continue;
   }

   if(deep && copy && (typeof copy == 'object')){ // 类型判断

    src = Object.prototype.toString.call(copy) == '[object Array]' ? [] : {}; //区分数组和‘对象'
    target[name] = extend(deep,src,copy);
   }else {

    if (copy !== undefined) {

    target[name] = copy;
    }
   }
   }
  }
  }

  return target
 }
Copier après la connexion

1. Jugement des paramètres, si le premier paramètre est de type booléen, il est pris comme paramètre profond. contrôle s'il faut copier en profondeur, la valeur par défaut de deep est false en même temps, l'élément cible sera le deuxième paramètre

2. Lors de la copie de la valeur de l'attribut, il est nécessaire de déterminer le type du paramètre profond et valeur d'attribut ; si deep est vrai et que la valeur d'attribut est un type d'objet, la fonction d'extension est appelée de manière récursive, sinon, attribuez directement

3. Il est nécessaire de faire la distinction entre les tableaux et les « objets » pour attribuer différentes valeurs initiales. valeurs aux propriétés de l'objet cible. S'ils sont tous {}, la valeur d'attribut du type tableau copiée dans l'élément cible deviendra {'0':xx, '1': xx...}

Conclusion

Toujours Ils utilisent tous directement $.extend(). C'est facile à utiliser mais je ne suis pas très clair sur l'implémentation. Je* ne suis peut-être pas rigoureux dans l'implémentation, mais je pense que la récolte est bonne.

Recommandations associées :

Méthodes pour implémenter la fonction de fusion d'objets

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal