js数据的深度迭代

    var _rawTostring = Object.prototype.toString;
    // 使用最原始的而不是直接调用对象的hasOwnerProperty,防止对象该属性被重写
    var _hasOwnerProperty = Object.prototype.hasOwnProperty;

    function type(target) {
        return _rawTostring.call(target).replace(/\[object (.+)?\]/,'$1');
    }

    function hasOwnerProperty(obj, key) {
        return _hasOwnerProperty.call(obj, key);
    }
    // 深度迭代
    /*   options => {
     *       fn, context, addition
     *   } 
     */
    function iterator(data, options) {
        options = options || {};
        if (type(data) === 'Object') {
            for (var key in data) {
                if (hasOwnerProperty(data, key)) {
                    var valType = type(data[key]);
                    if (valType === 'Object' || valType === 'Array') {
                        iterator(data[key], {
                            fn: options.fn,
                            context: options.context, 
                            addition: options.addition,
                            key: key,
                            type: valType
                        });
                    } else {
                        options.fn && options.fn.call(options.context, data[key], {
                            key: key, 
                            rawKey: options.key,
                            addition: options.addition,
                            rawType: options.type
                        });
                    }
                }
            }
        } else if(type(data) === 'Array'){
            for (var index = 0; index < data.length; index++) {
                var valType = type(data[index]);
                if (valType === 'Object' || valType === 'Array') {
                    iterator(data[index], {
                        fn: options.fn, 
                        context: options.context,
                        addition: options.addition,
                        type: valType
                    });
                } else {
                    options.fn && options.fn.call(options.context, data[index], {
                        key: index, 
                        rawKey: options.key,
                        addition: options.addition,
                        rawType: options.type
                    });
                }
            }
        }
    }

    module.exports = iterator;
    var iterator = require('./');    
    var data = {

      "contributors": [{
          "name": "test@qq.com"
      }],
      "description": "test ",
      "files": [
        "LICENSE",
        "README.md",
        "index.js",
        "test.js"
      ],
      "keywords": [
        "test"
      ],
      "license": "MIT",
      "maintainers": [{
          "name": "theanarkh",
          "email": "test@qq.com"
      }],
      "name": "test",
      "readme": "test in javascript",
      "repository": {
        "type": "git",
        "url": "test url"
      },
      "scripts": {},
      "version": "0.0.1"
    };


    iterator(data, {
        fn: (val, options) => {
            console.log(val)
        }
    });
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值