Uncaught TypeError: Object.values is not a function JavaScript
Uncaught TypeError: Object.values is not a function JavaScript
我有一个简单的对象,如下所示:
var countries = {
"Argentina":1,
"Canada":2,
"Egypt":1,
};
我需要创建两个数组。第一个数组是对象中所有键的数组。我通过以下方式创建了这个数组:
var labels = Object.keys(countries);
这很好用。我获得了一系列国家。现在,当我尝试从值创建数组时...
var labels = Object.values(countries);
我收到此错误:Uncaught TypeError: Object.values is not a function JavaScript
我不知道我做错了什么。我在声明 labels
之前和之后 console.log countries
并且对象保持不变。如何正确使用 Object.values()
?
许多浏览器不支持 .values
- 您可以使用 .map
获取所有值的数组:
var vals = Object.keys(countries).map(function(key) {
return countries[key];
});
参见 MDN 文档:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/values or Official doc: https://tc39.github.io/ecma262/#sec-object.values(感谢@evolutionxbox 的更正)
看起来此问题已在 Safari 最新版本中修复。我遇到了同样的问题。该问题出现在浏览器9.0.1版本,10.1.1不出现
正在编辑以添加附件:
[snippet][1]
[object value][2]
[browser version][3]
使用 "for...in",如 mozilla 所讨论:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_objects/Object/values
这是我使用的代码:
function objectValues(obj) {
let vals = [];
for (const prop in obj) {
vals.push(obj[prop]);
}
return vals;
}
// usage
let obj = {k1: 'v1', k2: 'v1', k3: 'v1'};
console.log(objectValues(obj)); // prints the array [ 'v1', 'v1', 'v1' ]
// OR
console.log(objectValues(obj).join(', ')); // prints the string 'v1, v1, v1'
我认为编译支持对浏览器兼容性有问题,您可以使用 map 来实现相同的目的。
var countries = [
{
"Argentina": 1,
"Canada": 2,
"Egypt": 1,
"india": 1
},
{
"Argentina": 1,
"india": 1,
"US": 2,
"UK": 1,
}
];
var unpick = countries.map(d=>{ return Object.keys(d) });
console.log(unpick)
var countries = [
{
"Argentina": 1,
"Canada": 2,
"Egypt": 1,
"india": 1
},
{
"Argentina": 1,
"india": 1,
"US": 2,
"UK": 1,
}
];
var unpick = countries.map(d=>{ return Object.values(d) });
console.log(unpick)
还值得注意的是,只有 Node 版本 >= 7.0.0 完全支持这一点。
对于那些最终来到这里并使用 Angular 的人,将 import 'core-js/es7/object';
添加到 polyfills.ts
文件解决了我的问题。
/** IE9, IE10 and IE11 requires all of the following polyfills. **/
import 'core-js/es6/array';
import 'core-js/es6/date';
import 'core-js/es6/function';
import 'core-js/es6/map';
import 'core-js/es6/math';
import 'core-js/es6/number';
import 'core-js/es6/object';
import 'core-js/es6/parse-float';
import 'core-js/es6/parse-int';
import 'core-js/es6/regexp';
import 'core-js/es6/set';
import 'core-js/es6/string';
import 'core-js/es6/symbol';
import 'core-js/es6/weak-map';
import 'core-js/es7/array';
import 'core-js/es7/object'; // added import
考虑使用 _.values(object)
我有一个简单的对象,如下所示:
var countries = {
"Argentina":1,
"Canada":2,
"Egypt":1,
};
我需要创建两个数组。第一个数组是对象中所有键的数组。我通过以下方式创建了这个数组:
var labels = Object.keys(countries);
这很好用。我获得了一系列国家。现在,当我尝试从值创建数组时...
var labels = Object.values(countries);
我收到此错误:Uncaught TypeError: Object.values is not a function JavaScript
我不知道我做错了什么。我在声明 labels
之前和之后 console.log countries
并且对象保持不变。如何正确使用 Object.values()
?
.values
- 您可以使用 .map
获取所有值的数组:
var vals = Object.keys(countries).map(function(key) {
return countries[key];
});
参见 MDN 文档:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/values or Official doc: https://tc39.github.io/ecma262/#sec-object.values(感谢@evolutionxbox 的更正)
看起来此问题已在 Safari 最新版本中修复。我遇到了同样的问题。该问题出现在浏览器9.0.1版本,10.1.1不出现
正在编辑以添加附件:
[snippet][1]
[object value][2]
[browser version][3]
使用 "for...in",如 mozilla 所讨论:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_objects/Object/values
这是我使用的代码:
function objectValues(obj) {
let vals = [];
for (const prop in obj) {
vals.push(obj[prop]);
}
return vals;
}
// usage
let obj = {k1: 'v1', k2: 'v1', k3: 'v1'};
console.log(objectValues(obj)); // prints the array [ 'v1', 'v1', 'v1' ]
// OR
console.log(objectValues(obj).join(', ')); // prints the string 'v1, v1, v1'
我认为编译支持对浏览器兼容性有问题,您可以使用 map 来实现相同的目的。
var countries = [
{
"Argentina": 1,
"Canada": 2,
"Egypt": 1,
"india": 1
},
{
"Argentina": 1,
"india": 1,
"US": 2,
"UK": 1,
}
];
var unpick = countries.map(d=>{ return Object.keys(d) });
console.log(unpick)
var countries = [
{
"Argentina": 1,
"Canada": 2,
"Egypt": 1,
"india": 1
},
{
"Argentina": 1,
"india": 1,
"US": 2,
"UK": 1,
}
];
var unpick = countries.map(d=>{ return Object.values(d) });
console.log(unpick)
还值得注意的是,只有 Node 版本 >= 7.0.0 完全支持这一点。
对于那些最终来到这里并使用 Angular 的人,将 import 'core-js/es7/object';
添加到 polyfills.ts
文件解决了我的问题。
/** IE9, IE10 and IE11 requires all of the following polyfills. **/
import 'core-js/es6/array';
import 'core-js/es6/date';
import 'core-js/es6/function';
import 'core-js/es6/map';
import 'core-js/es6/math';
import 'core-js/es6/number';
import 'core-js/es6/object';
import 'core-js/es6/parse-float';
import 'core-js/es6/parse-int';
import 'core-js/es6/regexp';
import 'core-js/es6/set';
import 'core-js/es6/string';
import 'core-js/es6/symbol';
import 'core-js/es6/weak-map';
import 'core-js/es7/array';
import 'core-js/es7/object'; // added import
考虑使用 _.values(object)