使用“for in”的最佳方式
best way to use "for in"
以前工作的代码在我添加 enyo.js 后现在在循环中失败了。我怀疑当我使用for(var ls in list)
即使长度为 0,它也会循环通过。当我调试时,我发现它正在考虑将"findIndex"视为列表中的值之一并进入循环。我有几个地方使用 for with in,我想找出一种过滤掉"findIndex"或任何无效索引的最佳方法,以便只有有效元素进入循环
for(var ls in list)
{
var lin = list[ls].rb ;
}
如果你列出是一个数组,只需使用常规的for
循环。这通常不是一个好主意用于...正是出于这个原因,也因为无法保证顺序。
如果必须使用for...in
请使用 hasOwnProperty 检查:
for (var ls in list)
{
if (list.hasOwnProperty(ls)) {
var lin = list[ls].rb;
// ...
}
}
当然,如果您只关心您是否拥有rb
属性,您可以对此进行测试:
if (list[ls].rb) {
var lin = list[ls].rb;
}
甚至:
var lin = list[ls].rb;
if (lin) {
// do whatever you needed to do with lin
}
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式