递归遍历对象和数组

2019-08-06  本文已影响0人  Huang_jing

1、实现对象的递归遍历

实现 {a: 11, b: {c: 22, d: 33, e: {f: 44, g: {h: 55}}}} \rightarrow {a: 11, c: 22, d: 33, f: 44, h: 55}  


var obj = {a: 11, b: {c: 22, d: 33, e: {f: 44, g: {h: 55}}}}

var newObj = {};

function copyObj(obj) {

    for (var key in obj) {

        // 这里使用递归,属性类型为对象则进一步遍历

        if (typeof obj[key] == 'object') {

            copyObj(obj[key])

        } else {

            newObj[key] = obj[key]

        }

    }

}

copyObj(obj)

console.log(newObj)


2、实现数组的递归遍历

实现  [11, [22, 33, [44, [55]]]] \rightarrow  [11, 22, 33, 44, 55]


var arr = [11, [22, 33, [44, [55]]]];

var newArr = [];

function copyArr(arr) {

    arr.map(item => {

        // 这里使用递归,属性类型为数组则进一步遍历

        if (Array.isArray(item)) {

            arguments.callee(item)  // 或copyArr(item)

        } else {

            newArr.push(item);

        }

    })

}

copyArr(arr)

console.log(newArr)

上一篇 下一篇

猜你喜欢

热点阅读