似乎当我在对象中使用数字类型作为键名时,它总是被转换为字符串。反正有没有把它作为数字存储?正常的类型转换似乎不起作用。
示例:
var userId = 1;
console.log( typeof userId ); // number
myObject[userId] = 'a value';
console.dir(myObject);
Dir输出:
{
'1': 'a value'
}
我想要的是:
{
1: 'a value'
}
么?
由于
答案 0 :(得分:70)
不,这是不可能的。 密钥将始终转换为字符串。请参阅Property Accessor docs
属性名称必须是字符串。这意味着非字符串对象不能用作对象中的键。任何非字符串对象(包括数字)都通过toString方法转换为字符串。
> var foo = {}
undefined
> foo[23213] = 'swag'
'swag'
> foo
{ '23213': 'swag' }
> typeof(Object.keys(foo)[0])
'string'
答案 1 :(得分:14)
在一个对象中,没有,但我发现Map对此应用程序非常有用。这是我用它来做数字键的地方,这是一个基于键的事件。
onKeydown(e) {
const { toggleSidebar, next, previous } = this.props;
const keyMapping = new Map([
[ 83, toggleSidebar ], // user presses the s button
[ 37, next ], // user presses the right arrow
[ 39, previous ] // user presses the left arrow
]);
if (keyMapping.has(e.which)) {
e.preventDefault();
keyMapping.get(e.which)();
}
}
答案 2 :(得分:9)
似乎是ECMA-262-5中的设计:
属性标识符类型用于将属性名称与属性描述符相关联。属性标识符类型的值是形式(名称,描述符)的对,其中name是String,描述符是属性描述符值。
但是,我在ECMA-262-3中没有看到明确的规格。 无论如何,我不会尝试使用非字符串作为属性名称。
答案 3 :(得分:1)
我们需要这样的东西吗?
var userId = 1;var myObject ={};
console.log( typeof userId ); // number
myObject[userId] = 'a value';
console.dir(myObject);
控制台: 对象
1 : “一个值”
答案 4 :(得分:0)
我认为你可以做以下事情,如果你想使用上面的东西来访问它,就像一个数字,我做了同样的工作。
var myObj = {"0":"a","1":"b","CNT":2};
$.each(myObj,function(key,value){
if(isNaN(parseInt(key))){
return true; //continue;
}
//Code to perform operation
}
仅当键不以数字字符开头时才有效,否则它将被转换为数字。请参阅以下示例:
parseInt("45kjghk") === 45
我在这里使用了jQuery
<强>更新强>
var myObj = {"0":"a","1":"b","CNT":2};
$.each(myObj,function(key,value){
if(isNaN(parseInt(key)) || (key.length !== parseInt(key).toString().length) ){
return true; //continue;
}
//Code to perform operation
}
它可以克服上述问题。如果有的话,请提出更好的建议(如果有的话)和问题。
答案 5 :(得分:0)
这是解决方案。如果这不起作用,请告诉我环境设置
const screens = {
"768": "large",
"200": "small"
}
const keys = Object.keys(screens).map(key => parseInt(key))
// OR Number(key)
console.log(keys) // Output [200, 768]
答案 6 :(得分:0)
每个 Mozilla: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_syntax[Spread 语法]1
let obj1 = { foo: 'bar', x: 42 };
let obj2 = { foo: 'baz', y: 13 };
const merge = ( ...objects ) => ( { ...objects } );
let mergedObj1 = merge (obj1, obj2);
// Object { 0: { foo: 'bar', x: 42 }, 1: { foo: 'baz', y: 13 } }
let mergedObj2 = merge ({}, obj1, obj2);
// Object { 0: {}, 1: { foo: 'bar', x: 42 }, 2: { foo: 'baz', y: 13 } }
只需提前订购商品,您就会得到想要的结果。
所以对于你的情况:
const merge = (...objects) => ({...objects});
//An object with numeric keys
const values = ["a value", "another value", "and another value"];
let merged = merge(...values);
console.log(merged);
答案 7 :(得分:0)
你可以试试这个:
arr = {}
function f(a,b,c) {
arr = arguments
}
f("*","#","_")
console.log(arr)
//returns Object { 0: "*", 1: "#", 2: "_" }```
答案 8 :(得分:-2)
在JavaScript中,数字字符串和数字是可以互换的,所以
myObject[1] == myObject['1']
如果您确实希望number为对象的键,您可能需要一个数组(即使用new Array()
或[]
创建)。