JavaScript-检查对象'的属性是一个数组
JavaScript - check if object's property is an array
我有以下对象:
const foo = {
prop1: 'I am a string',
prop2: [
{ prop2_1: 'I am a sub string' },
{ prop2_2: 'I am a sub string' },
],
prop3: 'I am a string',
prop4: [
{ prop4_1: 'I am a sub string' },
{ prop4_2: 'I am a sub string' },
],
}
在JavaScript(即不是jQuery)中,我如何循环遍历foo的属性并确定它的任何属性是否是数组?我尝试了这个,但没有运气:
for (const prop in foo) {
if (prop!== undefined) {
if (Object.prototype.toString.call(prop) === '[object Array]') {
prop.map((child) => {
// do something
});
}
}
}
您需要Array.isArray
。
您可能需要对此进行填充。
非递归
Object.keys(foo).some((k) => Array.isArray(foo[k]));
递归
function containsArr(o) {
for (var k of Object.keys(o)) {
if (recursive(o[k])) {
if (containsArr(o[k])) {
return true;
}
continue;
}
if (Array.isArray(o[k])) {
return true;
}
}
return false;
}
// We recurse into functions
// and plain objects.
function recursive(o) {
return /^'[object (Object)| (Function)']/
.test(Object.prototype.toString.call(o));
}
两个错误
首先,const-prop将失败,因为const是常量
其次,道具是关键,所以它永远不会是阵列
校正后的代码是
for (let prop in foo) {
if (foo.hasOwnProperty(prop)) {
if (Object.prototype.toString.call(foo[prop]) === '[object Array]') {
foo[prop].map((child) => {
// do something
});
}
}
}
相关文章:
- Javascript(Angular)从一个对象数组到第二个数组查找值
- 根据id将json数组组合为一个json数组
- JavaScript数组包含一个值
- 对一个对象使用reduce可以返回一个没有't在数组中包含目标字母
- jQuery$.inArray()总是返回-1和一个对象数组
- 在数组中的一个元素上设置多个值
- javascript处理一个对象数组以获得一个新的对象数组
- 作为一个二维数组,从ajax接收
- 你能用来自数组的属性名称生成一个对象吗
- 多维关联数组的最后一个索引
- 如何创建一个方法来验证数组的范围
- 循环以检查数组中的最后一个图像
- 在Javascript中将一个值和字符串数组转换为if语句
- 算法:从数组(javascript/angular)中按当前日期获取上一个和下一个事件
- 如何将一个对象添加到每个对象数组中
- 如何创建一个谷歌地图地理坐标数组
- 如何从另一个带下划线的数组中筛选带元素的数组
- 使用window.location.htm和匹配的URL数组(一个用于桌面,一个用于移动)将桌面网站重定向到移动
- Javascript排序多维数组-一个完整的例子
- 刽子手的游戏.2数组.一个需要相应地更新另一个