【问题标题】:How to turn dot notation string into an object in Javascript如何在Javascript中将点符号字符串转换为对象
【发布时间】:2018-03-01 10:39:39
【问题描述】:

我正在尝试将点符号字符串转换为对象,例如给定

  [{
      key: 'app.team.instance',
      value: 'some value1'
  }, {
      key: 'app.team.instance.obj',
      value: 'some value'
  }, {
      key: 'app.team.app.some',
      value: 'some value'
  }, {
      key: 'app.service.awesome.more',
      value: 'more values'
  }]

我想把它变成一个想要得到的对象

 {
  "team": {
      "instance": "some value1",
      "server": {
          "obj": "some value"
      },
      "app": {
          "some": "some value"
      }
  },
  "service": {
      "awesome": {
          "more": "more values"
      }
  }
}

这是我尝试使用以下功能的方法。查看我的功能,我遗漏了什么或应该改进什么?

function createObjFromRows(skip, key, value, obj) {
    const ARRAY_KEYS = key.split('.');
    const ARRAY_LENGTH = ARRAY_KEYS.length;

    let i = skip ? 1 : 0;

    for (; i < ARRAY_LENGTH; i++) {
        if (i < (ARRAY_LENGTH - 1)) {
            if (!obj.hasOwnProperty(ARRAY_KEYS[i])) { obj[ARRAY_KEYS[i]] = {}; }
        } else {
            obj[ARRAY_KEYS[i - 1]][ARRAY_KEYS[i]] = value;
        }
    }
}

这是我目前得到的。

{
    team: {
        instance: 'some value1'
    },
    server: {
        obj: 'some value'
    },
    app: {
        some: 'some value'
    },
    service: {},
    awesome: {
        more: 'more values'
    }
}

【问题讨论】:

标签: javascript


【解决方案1】:

您可以使用array.prototype.reduce

  var datas = [ {key: 'app.team.instance', value: 'some value1'}, {key: 'app.team.server.obj', value: 'some value'}, {key: 'app.team.app.some',value: 'some value'}, {key: 'app.service.awesome.more', value: 'more values'}];

var res = datas.reduce((m, o) => {
    var keys = o.key.split('.');
    var cur = m;
    keys.forEach((key, i) => { 
        if (i < keys.length - 1) {
            cur[key] = cur[key] || {};
            cur = cur[key];
        } else {
            cur[key] = o.value;
        }
    });
    return m;
}, {});

console.log(res);

【讨论】:

    【解决方案2】:

    在将键迭代到嵌套属性后,您可以拆分给定的键字符串并保存最后一个键以分配值。

    var data = [{ key: 'app.team.instance', value: 'some value1' }, { key: 'app.team.server.obj', value: 'some value' }, { key: 'app.team.app.some', value: 'some value' }, { key: 'app.service.awesome.more', value: 'more values' }],
        result = data.reduce(function (r, o) {
            var path = o.key.split('.'),
                last = path.pop();
    
            path.reduce(function (p, k) {
                return p[k] = p[k] || {};
            }, r)[last] = o.value;
            return r;
        }, {});
    
    console.log(result);
    .as-console-wrapper { max-height: 100% !important; top: 0; }

    【讨论】:

      猜你喜欢
      • 2011-10-05
      • 2016-09-27
      • 2021-08-21
      • 2020-12-30
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-09-29
      相关资源
      最近更新 更多