133

似乎当我在对象中使用数字类型作为键名时,它总是被转换为字符串。反正有没有真正让它存储为数字?正常的类型转换似乎不起作用。

例子:

var userId = 1;
console.log( typeof userId ); // number
myObject[userId] = 'a value';
console.dir(myObject);

目录输出:

{
    '1': 'a value'
}

想要的是这样的:

{
    1: 'a value'
}

建议?

4

9 回答 9

150

不,这是不可能的。 密钥将始终转换为字符串。请参阅属性访问器文档

属性名称必须是字符串。这意味着非字符串对象不能用作对象中的键。任何非字符串对象,包括数字,都通过 toString 方法类型转换为字符串。

> var foo = {}
undefined

> foo[23213] = 'swag'
'swag'

> foo
{ '23213': 'swag' }

> typeof(Object.keys(foo)[0])
'string'
于 2010-09-03T06:04:26.540 回答
36

在一个对象中,不,但我发现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)();
  }
}
于 2016-05-31T16:46:02.800 回答
13

似乎是 ECMA-262-5 中的设计:

属性标识符类型用于将属性名称与属性描述符相关联。Property Identifier 类型的值是 (name, descriptor) 形式的对,其中 name 是 String,descriptor 是 Property Descriptor 值。

但是,我在 ECMA-262-3 中没有看到明确的规范。无论如何,我不会尝试使用非字符串作为属性名称。

于 2010-09-03T07:08:24.493 回答
3

这是解决方案。如果这不起作用,请告诉我环境设置

const screens = {
    "768": "large",
    "200": "small"
}

const keys = Object.keys(screens).map(key => parseInt(key))
                                         // OR Number(key)

console.log(keys) // Output [200, 768]
于 2020-11-17T05:47:32.220 回答
2

我们需要这样的东西吗?

var userId = 1;var myObject ={};
console.log( typeof userId ); // number
myObject[userId] = 'a value';
console.dir(myObject);

控制台:对象

1:“一个值”

于 2018-09-05T07:54:43.660 回答
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
}

它可以克服上述问题。如果可用,请提出更好的建议,如果有,请提出这个答案的问题。

于 2018-05-29T06:44:54.303 回答
0

每个 Mozilla: https ://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_syntax[扩展语法] 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);

于 2021-01-08T23:15:08.507 回答
-1

你可以试试这个:

arr = {}
function f(a,b,c) {
      arr = arguments
}
f("*","#","_")
console.log(arr)
//returns Object { 0: "*", 1: "#", 2: "_" }```
于 2021-06-23T14:26:10.490 回答
-4

在 JavaScript 中,数字字符串和数字是可以互换的,所以

myObject[1] == myObject['1']

如果您真的希望数字成为对象的键,您可能需要一个数组(即使用new Array()or创建[])。

于 2010-09-03T06:02:56.850 回答