数据拦截器:递归遍历对象/数组,回调提供对属性,值的修改接口

/**
 * 数据拦截器:
 * 
 *     对复杂类型数据做深度递归,提供修改拦截属性,回调中可对属性,值等做处理
 *
 * @param {*} data  object/array  需要拦截的目标(数组或对象)
 * @param {*} callback1 function  回调函数 在内部对最内层(value为基础类型,再无嵌套)的value做一些事情,回调参数为一个obj
 * @param {*} callback2 function  同上,区别在于value为复杂类型,有嵌套
 * 回调参数说明:
 *      {
            type: 'Object',// 'Object'|'Array' 父节点的类型
            obj: data,      //  父节点对象(引用)
            key: key,       //  当前的key(ps:type为'Array'即为当前索引)
            value: value    //  当前的value
        }
 *  应用场景1:
        当你的项目中需要对特殊数据做处理的时候,比如测试说页面不能出现null!
        此时你可以在数据渲染之前调用此函数,在callback1中对value做一些处理

    应用场景2(最初写此函数的目的):
        对echarts的options进行个性化设置,data支持多种配置方式,不同的方式
        做不同的处理,用此函数在callback2中对data做一些处理后再setOption
 */
function dataInterceptor(data, callback1, callback2) {

    again(data)

    function again(data) {

        if (type(data) === 'Object') {

            for (var key in data) {
                // console.log('key------',key)   ----所有的key都经过这里
                if (typeof data[key] === "object"&&data[key]!==null) {
                    // 父节点是对象,值为复杂类型
                    if (callback2) callback2({
                        type: 'Object',
                        obj: data,
                        key: key,
                        value: data[key]
                    })
                    again(data[key])
                } else {
                    // console.log(data[key])
                    //  父节点是对象,值为基础类型
                    if (callback1) callback1({
                        type: 'Object',
                        obj: data,
                        key: key,
                        value: data[key]
                    })
                }
            }

        } else if (type(data) === 'Array') {
            data.forEach(function (item, index) {
                if (typeof item === "object"&&item!==null) {
                    // 父节点是数组 ,值为复杂类型
                    if (callback2) callback2({
                        type: 'Array',
                        obj: data,
                        key: index,
                        value: item
                    })
                    again(item)
                } else {
                    //  父节点是数组,值为基础类型--->数组的每一项
                    // console.log(item)
                    if (callback1) callback1({
                        type: 'Array',
                        obj: data,
                        key: index,
                        value: item
                    })
                }
            })
        }
    }

    function type(data) {
        return Object.prototype.toString.call(data).slice(8, -1)
    }
}

 

posted @ 2019-09-20 16:15  superjsman  阅读(471)  评论(0编辑  收藏  举报