zoukankan      html  css  js  c++  java
  • JavaScript中Object值合并方法

    前言:在日常开发工作中我们可能会遇到js中对象中所有值的复制工作,也有可能是通过electron开发客户端,改版时候面临到的设置合并问题。那么本文将对此做一个简要解决方案的叙述。

    介绍:比如有obj1, obj2,我们需要将obj1中的所有与obj2中相同字段相同深度的值copy给obj2,并且需要保持obj2字段结构不变,调用一下方法即可(采用ES6写法)。

     1 /**
     2          * 将src中的数据copy到dist中,并保留dist的结构
     3          * @param src
     4          * @param dist
     5          */
     6         copyValue(src, dist) {
     7             if (!src || typeof(src) !== 'object' || typeof(dist) !== 'object'){
     8                 return ;
     9             }
    10 
    11             let keys = Object.keys(dist)
    12             if (keys && keys.length > 0 && isNaN(keys[0])){
    13                 keys.forEach(key => {
    14                     let value = dist[key]
    15                     let srcVal = src[key]
    16 
    17                     // 判断是不是对象,如果是则继续遍历,不是则开始赋值或忽略
    18                     if (value !== undefined && typeof(value) === 'object' && srcVal && typeof(srcVal) === 'object' && srcVal[0] === undefined){
    19                         copyValue(srcVal, value)
    20                     } else if (value !== undefined && srcVal && typeof(value) == typeof (srcVal)){
    21                         // 如果源数据存在,并且类型一致,则开始赋值
    22                         dist[key] = src[key]
    23                     }
    24                 })
    25             }
    26 
    27         },

    谢谢收看,我是fullstackyang!

  • 相关阅读:
    T-SQL 关闭数据库所有连接
    单页web应用(SPA)的简单介绍
    ES6—解构赋值
    ES6 — 新增关键字let、const
    一行能装逼的JavaScript代码
    Date 对象总结
    JS从头开始
    CSS基础知识点(二)——居中
    web标准的可用性和可访问性
    CSS基础知识点(二)——选择器
  • 原文地址:https://www.cnblogs.com/fullstack-yang/p/8085206.html
Copyright © 2011-2022 走看看