js递归替换object嵌套的指定value

/**
 * 
 * @param {Object} obj //原数据
 * @param {*} value //替换前的值
 * @param {*} replace //替换后的值
 * @return {Object} //替换后的数据
 */
function replaceObjData(obj, value, replace) {
    //判断类型
    if (typeof obj === 'object') {
        // 数组(不要用for in)
        if (Array.isArray(obj)) {
            console.log(obj, '是数组')
            for (let i = 0; i < obj.length; i++) {
                obj[i] = replaceObjData(obj[i], value, replace);
            }
        } else {
            console.log(obj, '是对象')
            for (let key in obj) {
                obj[key] = replaceObjData(obj[key], value, replace);
            }
        }
        return obj
    } else {
        return obj = obj === value ? replace : obj;
    }
}
let obj = {a: 'a1',b: 'a1',c: ['a1', 'a1']}
//将以上数据的value'a1'全部替换成'b1'
let res= replaceObjData(obj,'a1','b1')
console.log(res) //{a: 'b1',b: 'b1',c: ['b1', 'b1']}
JavaScript中,使用递归方法来处理嵌套JSON数据是一种常见的做法。这种方法允许我们深入JSON对象的每一层,以访问和处理那些具有动态键名的深层数据。以下是一个示例代码,展示了如何使用递归函数来遍历嵌套JSON并获取动态: ```javascript function extractKeyValuePairs(obj) { const result = {}; for (const [key, value] of Object.entries(obj)) { if (typeof value === 'object' && value !== null) { // 如果对象递归调用 const nestedResult = extractKeyValuePairs(value); // 将子对象的键对添加到结果中,键名使用当前key作为前缀 for (const [nestedKey, nestedValue] of Object.entries(nestedResult)) { result[`${key}.${nestedKey}`] = nestedValue; } } else { // 如果不是对象,直接记录键对 result[key] = value; } } return result; } // 示例使用 const nestedJson = { a: 1, b: { c: 2, d: { e: 3 } } }; const extractedKeyValuePairs = extractKeyValuePairs(nestedJson); console.log(extractedKeyValuePairs); // 输出: { "a": 1, "b.c": 2, "b.d.e": 3 } ``` 这段代码定义了一个`extractKeyValuePairs`函数,它接受一个JSON对象作为参数。函数内部,我们创建了一个新的空对象`result`来存储最终的键对。接着,我们遍历传入的JSON对象的每个键对。如果当前的对象类型(并且不为`null`),则递归调用`extractKeyValuePairs`函数,并将返回的结果作为子键对添加到结果对象中。如果当前的不是对象,则直接将其键对添加到结果对象中。最终,函数返回包含所有深层键对的结果对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值