我有一个空对象和一个字符串:
var obj = {};
var str = "a.b.c";
有没有办法可以把它变成
obj = { a: { b: { c: { } } } }
我无法完全围绕这一个,我甚至不确定它是否可能。
答案 0 :(得分:8)
var obj = {};
var str = "a.b.c";
var arr = str.split('.');
var tmp = obj;
for (var i=0,n=arr.length; i<n; i++){
tmp[arr[i]]={};
tmp = tmp[arr[i]];
}
ES6:
let str = "a.b.c",
arr = str.split('.'),
obj, o = obj = {};
arr.forEach(key=>{o=o[key]={}});
console.log(obj);
ES6 /减少(不需要阵列存储):
let str = "a.b.c", obj, o = obj = {};
str.split('.').forEach(key=>o=o[key]={});
console.log(obj);
ES6 / Array.prototype.reduce:
let str = "a.b.c", last;
let obj = str.split('.').reduce((o, val) => {
if (typeof last == 'object')
last = last[val] = {};
else
last = o[val] = {};
return o;
}, {});
console.log(obj);
答案 1 :(得分:3)
这是来自yui2 yahoo.js文件。
YAHOO.namespace = function() {
var a=arguments, o=null, i, j, d;
for (i=0; i<a.length; i=i+1) {
d=(""+a[i]).split(".");
o=YAHOO;
// YAHOO is implied, so it is ignored if it is included
for (j=(d[0] == "YAHOO") ? 1 : 0; j<d.length; j=j+1) {
o[d[j]]=o[d[j]] || {};
o=o[d[j]];
}
}
return o;
};
请参阅文档来源。
https://github.com/yui/yui2/blob/master/src/yahoo/js/YAHOO.js
答案 2 :(得分:3)
此递归函数返回所需对象的字符串表示
//Usage: getObjectAsString('a.b.c'.split(/\./))
function getObjectAsString (array){
return !array.length ? '{}'
: '{"' + array[0] + '":' + getObjectAsString (array.slice(1)) + '}';
}
现在可以使用
将getObjectAsString的输出转换为对象JSON.parse(getObjectAsString('a.b.c'.split(/\./)))
编辑:删除了“输入为字符串”版本,因为它仅适用于命名空间中的单个字母子部分,例如问题(abc)中给出的子部分,通常不是这种情况。
答案 3 :(得分:0)
你走了:
var string = "a.b.c",
array = string.split('.');
JSON.parse("{\"" + array.join('": {\"') + "\": {" +array.map(function () {return '}'}).join('') + "}")
答案 4 :(得分:0)
这是我的看法:
function ensureKeys(str, obj) {
for(var parts = str.split('.'), i=0, l=parts.length, cache=obj; i<l; i++) {
if(!cache[parts[i]]) {
cache[parts[i]] = {};
}
cache = cache[parts[i]];
}
return obj;
}
var obj = {};
ensureKeys('a.b.c', obj);
// obj = { a: { b: { c: {} } } }