如何解决在括号之间声明一个 javascript 对象以仅选择与其索引对应的元素
我在一本书中发现了这个样本,这是我第一次看到这个符号。
显然,它比切换要短一千倍;但它是什么?
当我执行 typeof(status)
时,它返回 undefined。
我想了解它是什么,以便我可以在接下来的代码中更频繁地应用它!
function statusformId(id) {
const status = ({
0: 'in the bed',1: 'face to your computer',2: 'a little bit silly',3: 'Nowhere'
})[id];
return status || 'UnkNow status: ' + id;
}
console.log('statusformId(2) ...',statusformId(2)); // a little bit silly
console.log('statusformId() ...',statusformId()); // UnkNow status: undefined
谢谢!
解决方法
首先进行一些修复
- 在函数之前添加“函数”。
这是一个工作示例:
function statusformId(id){
const status = (
{
0: 'in the bed',1: 'face to your computer',2: 'a little bit silly',3: 'nowhere'
}
)[id];
return status || 'Unknow status: '+id
}
console.log(statusformId(0));
console.log(statusformId(1));
console.log(statusformId(2));
console.log(statusformId(3));
console.log(statusformId(4));
哪个会返回
in the bed
face to your computer
a little bit silly
nowhere
Unknow status: 4
原因:
这表示一个带有一些索引的对象,其中 0 具有值,“在床上”,...。
{
0: 'in the bed',3: 'nowhere'
}
将对象包装在子表达式中并添加索引将创建对象并返回传递索引的值。
const status = (
{
0: 'in the bed',3: 'nowhere'
}
)[id];
当使用对象未知的 id 时,返回 undefined。
使用 ||
将返回 'Unknow status: '+id
当 status 为假值(如 undefined,null,false,... ),否则返回实际值。
return status || 'Unknow status: '+id
,
const a = {0:'zero'}
console.log(a[0]);
与
相同const a = ({0:'zero'})[0]
console.log(a);
您最终尝试通过索引访问对象属性。你的代码可以写成如下。
function statusformId(id){
const status = {
0: 'in the bed',3: 'nowhere'
}
return status[id] || 'Unknow status: '+id
}
PS - 你的代码片段是错误的。您错误地在代码块中添加了一个额外的“}”
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。