js递归实现包名转换成对应的层级对象c

页面导航:首页 > 网络编程 > JavaScript > js递归实现包名转换成对应的层级对象c

js递归实现包名转换成对应的层级对象c

来源: 作者: 时间:2016-01-23 10:23 【

示例:由原对象{a: {test: 1, b: 2}} 根据a b c d这样的包名转换为:{a:{test:1,b:{c:{d:{}}}}}说明:包名有 分隔,本身代表着层级结构,而json对象本身也是由属性和值构成的,允许嵌套,因此现在就有一个需

示例:由原对象{a: {test: 1, b: 2}} 根据a.b.c.d这样的包名转换为:{a:{test:1,b:{c:{d:{}}}}}

说明:包名有.分隔,本身代表着层级结构,而json对象本身也是由属性和值构成的,允许嵌套,因此现在就有一个需求,把包的描述字符串,转换成json类型,条件是要注意到已经存在的其他属性.本例中属性a的值是对象,因此要保留该,只对其内容做扩展,而属性b的值不是对象类型,因此要用对象覆盖掉,其他不存在的属性,要付给空对象.

本例使用递归实现:

 

function namespace(oNamespace, sPackage) {
    var obj = oNamespace;
   var  pkg = ;
    if(sPackage.indexOf(.)==-1){
		pkg = sPackage;
	}else{
		pkg = sPackage.substr(0,1);
	}
	if(pkg&&!(obj[pkg]&&obj[pkg] instanceof Object)){
		obj[pkg] = {};
	}
	if(sPackage.indexOf(.)!=-1){
		namespace(obj[pkg],sPackage.substr(2));
	}
	
    return obj;
}
测试代码:

 

 

var obj = namespace({a: {test: 1, b: 2}}, 'a.b.c.d');
console.log(JSON.stringify(obj));

结果:

 

 

{a:{test:1,b:{c:{d:{}}}}} 

 

 



Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<