将平面结构转换为对象

时间:2015-08-19 08:49:39

标签: javascript node.js mongodb mongoose

在我尝试为Mongo DB和Mongoose制作通用CRUD系统时,我遇到了这个挑战。当用户更新记录并读取req.body时,字段以平面结构返回。但是我的一些模型有嵌套记录,因此是点符号。

我需要将下面的内容展开到一个对象中,以便将其传递给Mongo DB。

我有:

var data = {
    'details.location.unit': undefined,
    'details.location.floor': undefined,
    'details.location.streetNumber': '67',
    'details.location.streetName': 'Brown St',
    'details.location.suburb': 'potts point',
    'details.location.postcode': 2011,
    'details.location.city': 'sydney',
    'details.location.state': 'nsw',
    'details.location.country': 'australia',
    'details.contact.phone': [ '(02) 2376 5678', '(02) 1234 5678' ],
    'details.contact.url': 'http://www.example.com',
    'details.contact.email': 'me@example.com'
}

想把它变成:

var data = {
    details:{
        location: {
            unit': undefined,
            floor': undefined,
            streetNumber': '67',
            streetName': 'Brown St',
            suburb': 'potts point'
        },

        contact: {
          phone': [ '(02) 2376 5678', '(02) 1234 5678' ],
          url: 'http://www.example.com',
          email: 'me@example.com',  
        }
    }
}

注意那里的数组。这需要进行JSON解析。不太确定如何攻击这个!

对于项目的另一部分,我使用此函数通过字符串访问器访问对象。也许它可以改变用途?

// @param {object} data
// @param {string} accessor e.g 'vehicles.cars.toyota'
// @return {*}
var getValueByAccessor = function (data, accessor) {

    var keys = accessor.split('.'),
        result = data;

    while (keys.length > 0) {
        var key = keys.shift();

        if (typeof result[key] !== 'undefined') {
            result = result[key];
        }

        else {
            result = null;
            break;
        }
    }

    return result;
}

1 个答案:

答案 0 :(得分:0)

var data = {
    'details.location.unit': undefined,
    'details.location.floor': undefined,
    'details.location.streetNumber': '67',
    'details.location.streetName': 'Brown St',
    'details.location.suburb': 'potts point',
    'details.location.postcode': 2011,
    'details.location.city': 'sydney',
    'details.location.state': 'nsw',
    'details.location.country': 'australia',
    'details.contact.phone': [ '(02) 2376 5678', '(02) 1234 5678' ],
    'details.contact.url': 'http://www.example.com',
    'details.contact.email': 'me@example.com'
}

var setNewValue = function (obj, chain, value) {
    var i = 0;
    while (i < chain.length - 1) {
        obj[chain[i]]=obj[chain[i]] || {};
        obj = obj[chain[i]];
        i++;
    }
    obj[chain[i]] = value;
};

var convertedObject={};
for(var a in data)if(data.hasOwnProperty(a)){
    var pathArr=a.split('.');
    var value=data[a];
    setNewValue (convertedObject, pathArr, value);
}