中文字幕一区二区人妻电影,亚洲av无码一区二区乱子伦as ,亚洲精品无码永久在线观看,亚洲成aⅴ人片久青草影院按摩,亚洲黑人巨大videos

JavaScript深度合并

發(fā)布于:2021-02-17 00:02:23

0

120

0

JavaScript 深度合并

我最近分享了如何使用傳播運算符合并對象屬性, 但是此方法有一個很大的局限性:傳播運算符合并不是“深度”合并,這意味著合并是遞歸的。此外,嵌套對象的屬性不會合并-合并中指定的最后一個值將替換最后一個,即使應該存在其他屬性也是如此。

const defaultPerson = {
 name: 'Anon',
 gender: 'Female',
 hair: {
   color: 'brown',
   cut: 'long'
 },
 eyes: 'blue',
 family: ['mom', 'dad']
};

const me = {
 name: 'David Walsh',
 gender: 'Male',
 hair: {
   cut: 'short'
 },
 family: ['wife', 'kids', 'dog']
};

const summary = {...defaultPerson, ...me};

/*
{  
  "name":"David Walsh",
  "gender":"Male",
  "hair":{  
     "cut":"short"
  },
  "eyes":"blue",
  "family":[  
     "wife",
     "kids",
     "dog"
  ]
}
*/

在上面的示例中,您會注意到hair 對象的color 消失了而不是合并了,因為散布運算符只保留最后提供的值,在這種情況下為me.hair。相同的合并問題也適用于數(shù)組-您會注意到mom ,dad 而不是從defaultPerson對象的family數(shù)組中合并。

JavaScript中的深度合并很重要,尤其是在具有許多屬性的“默認”或“選項”對象以及通常與實例特定值合并的嵌套對象的常規(guī)做法中。如果您正在尋找可用于深度合并的實用程序,那就比微型的deepmerge實用程序好!

使用該deepmerge 實用程序時,可以將任意數(shù)量的對象(包括數(shù)組)遞歸合并到一個最終對象中。讓我們來看看!

const deepmerge = require('deepmerge');

// ...

const summary = deepmerge(defaultPerson, me);

/*
{  
  "name":"David Walsh",
  "gender":"Male",
  "hair":{  
     "color":"brown",
     "cut":"short"
  },
  "eyes":"blue",
  "family":[  
     "mom",
     "dad",
     "wife",
     "kids",
     "dog"
  ]
}
*/

deepmerge可以處理更復雜的合并:嵌套對象和deepmerge.all合并兩個以上的對象:

const result = deepmerge.all([,
 { level1: { level2: { name: 'David', parts: ['head', 'shoulders'] } } },
 { level1: { level2: { face: 'meh', parts: ['knees', 'toes'] } } },
 { level1: { level2: { eyes: 'more meh', parts: ['eyes'] } } },]);/*
{  
  "level1":{  
     "level2":{  
        "name":"David",
        "parts":[  
           "head",
           "shoulders",
           "knees",
           "toes",
           "eyes"
        ],
        "face":"meh",
        "eyes":"more meh"
     }
  }
}
*/

deepmerge 是一個了不起的實用程序,是相對較少的代碼:

function isMergeableObject(val) {
   var nonNullObject = val && typeof val === 'object'

   return nonNullObject        && Object.prototype.toString.call(val) !== '[object RegExp]'
       && Object.prototype.toString.call(val) !== '[object Date]'}function emptyTarget(val) {
   return Array.isArray(val) ? [] : {}}function cloneIfNecessary(value, optionsArgument) {
   var clone = optionsArgument && optionsArgument.clone === true
   return (clone && isMergeableObject(value)) ? deepmerge(emptyTarget(value), value, optionsArgument) : value}function defaultArrayMerge(target, source, optionsArgument) {
   var destination = target.slice()
   source.forEach(function(e, i) {
       if (typeof destination[i] === 'undefined') {
           destination[i] = cloneIfNecessary(e, optionsArgument)
       } else if (isMergeableObject(e)) {
           destination[i] = deepmerge(target[i], e, optionsArgument)
       } else if (target.indexOf(e) === -1) {
           destination.push(cloneIfNecessary(e, optionsArgument))
       }
   })
   return destination}function mergeObject(target, source, optionsArgument) {
   var destination = {}
   if (isMergeableObject(target)) {
       Object.keys(target).forEach(function (key) {
           destination[key] = cloneIfNecessary(target[key], optionsArgument)
       })
   }
   Object.keys(source).forEach(function (key) {
       if (!isMergeableObject(source[key]) || !target[key]) {
           destination[key] = cloneIfNecessary(source[key], optionsArgument)
       } else {
           destination[key] = deepmerge(target[key], source[key], optionsArgument)
       }
   })
   return destination}function deepmerge(target, source, optionsArgument) {
   var array = Array.isArray(source);
   var options = optionsArgument || { arrayMerge: defaultArrayMerge }
   var arrayMerge = options.arrayMerge || defaultArrayMerge    if (array) {
       return Array.isArray(target) ? arrayMerge(target, source, optionsArgument) : cloneIfNecessary(source, optionsArgument)
   } else {
       return mergeObject(target, source, optionsArgument)
   }}deepmerge.all = function deepmergeAll(array, optionsArgument) {
   if (!Array.isArray(array) || array.length < 2) {
       throw new Error('first argument should be an array with at least two elements')
   }

   // we are sure there are at least 2 values, so it is safe to have no initial value
   return array.reduce(function(prev, next) {
       return deepmerge(prev, next, optionsArgument)
   })}

功能強大的小代碼?那是我最喜歡的實用程序類型!  deepmerge 有充分的理由在整個網(wǎng)絡上使用!