js递归实现包名转换成对应的json对象
2015-06-13 21:15
369 查看
示例:由原对象{a: {test: 1, b: 2}} 根据a.b.c.d这样的包名转换为:{"a":{"test":1,"b":{"c":{"d":{}}}}}
说明:包名有"."分隔,本身代表着层级结构,而json对象本身也是由属性和值构成的,允许嵌套,因此现在就有一个需求,把包的描述字符串,转换成json类型,条件是要注意到已经存在的其他属性.本例中属性a的值是对象,因此要保留该,只对其内容做扩展,而属性b的值不是对象类型,因此要用对象覆盖掉,其他不存在的属性,要付给空对象.
本例使用递归实现:
结果:
功能是做出来了,但不用递归是不是也能实现呢?我现在脑子乱,不想做了,请读者思考?
说明:包名有"."分隔,本身代表着层级结构,而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":{}}}}}
功能是做出来了,但不用递归是不是也能实现呢?我现在脑子乱,不想做了,请读者思考?
相关文章推荐
- Extjs4.0 最新最全视频教程
- Javascript中toFixed方法的改进
- 5个常见可用性错误和解决方案
- XML 与 JSON 优劣对比
- js可突破windows弹退效果代码
- newtonsoft.json解析天气数据出错解决方法
- JSP脚本漏洞面面观
- 使用BAT一句话命令实现快速合并JS、CSS
- Lua模块与包学习笔记
- js显示当前星期的起止日期的脚本
- C#中的递归APS和CPS模式详解
- WinForm实现按名称递归查找控件的方法
- vbs 解析json jsonp的方法
- 爆炸式的JS圆形浮动菜单特效代码
- C#中的尾递归与Continuation详解
- js select常用操作控制代码
- 从jsp发送动态图像
- 原生js结合html5制作小飞龙的简易跳球
- jquery JSON的解析方式示例介绍
- js 页面模块自由拖动实例