javascript - 如何通过参数获取Object的子节点?
问题描述
代码如下:
let china = { zhejiang: {hangzhou: ’xihu’ }}// xihuconsole.log(china.zhejiang.hangzhou)// xihuconsole.log(china[’zhejiang’][’hangzhou’])// 能否通过 key 来访问 china 使之能输出 xihuconsole.log( china[key] )
问题解答
回答1:let china = { zhejiang: {hangzhou: ’xihu’ }};//改造结构Object.keys(china).forEach(function(key){ Object.keys(china[key]).forEach(function(subkey){china[subkey] = china[key][subkey]; });});console.log( china[’hangzhou’] );/* xihu*/回答2:
你的意思是这样?
let key = ’zhejiang’;console.log( china[key] )
还是这样?es2015允许使用变量做为key:
var b = ’foo’;var o ={ [b] :’aa’};o[b]//aa
如果不是的话,直接china[key],key会因为没有定义报错吧
回答3:不能这样,除非你for...in遍历一下,输出xihu
相关文章:
1. css3 - Firefox 字号相对IE、Chrome更大,如何在CSS中统一?2. html5 - HTML代码中的文字乱码是怎么回事?3. javascript - 微信小程序 wx.downloadFile下载文件大小有限制吗4. android - 求 360浏览器 百度浏览器 搜狗浏览器的最新启动类名5. php laravel框架模型作用域6. css3动画 - 实现css3推倒动画7. python 读取csv文件可以读取但内容错误,但单独用excel打开正常,如何解决?8. css - ul ol前边的标记如何调整样式呢9. css - 前端flex布局嵌套内层的布局不起作用?10. 微信端电子书翻页效果