js 数组遍历 对象遍历

一、数组遍历

1,普通for循环,经常用的数组遍历

var arr = [1,2,0,3,9];
 for ( var i = 0; i <arr.length; i++){
    console.log(arr[i]);
}

2,优化版for循环:使用变量,将长度缓存起来,避免重复获取长度,数组很大时优化效果明显

for(var j = 0,len = arr.length; j < len; j++){
    console.log(arr[j]);
}

 3,forEach,ES5推出的,数组自带的循环,主要功能是遍历数组,实际性能比for还弱。不能使用break语句中断循环,也不能使用return语句返回到外层函数。ie9以下的浏览器不支持

arr.forEach(function(value,i){
  console.log('forEach遍历:'+i+'--'+value);
})

4,map遍历,map即是 “映射”的意思 用法与 forEach 相似 支持使用return语句,支持return返回值。ie9以下的浏览器不支持

复制代码
arr.map(function(value,index){
    console.log('map遍历:'+index+'--'+value);
});
 
var temp=arr.map(function(val,index){
  console.log(val); 
  return val*val          
})
console.log(temp);
复制代码

5,for-of遍历 是ES6新增功能 避开了for-in循环的所有缺陷 可以正确响应break、continue和return语句 。

 不仅支持数组,还支持大多数类数组对象,例如DOM NodeList对象。也支持字符串遍历。

for( let i of arr){
    console.log(i);
}

二、对象遍历

示例:

复制代码
var obj = {
  "name": "Poly",
  "career": "it"
}
Object.defineProperty(
obj, "age", 
{ value:"forever 18", enumerable:false }
);
Object.prototype.protoPer1 = function(){console.log("proto");};
Object.prototype.protoPer2 = 2;
复制代码

 

1,for-in遍历

用于遍历对象的可枚举属性,包括自有属性、继承自原型的属性

for-in是为遍历对象而设计的,不适用于遍历数组。

遍历数组的缺点:数组的下标index值是数字,for-in遍历的index值"0","1","2"等是字符串

for(var a in obj){
  console.log(a);
}
//输出:name, career, protoPer1, protoPer2

2.Object.keys

返回一个数组,元素均为对象自有的可枚举属性

console.log(Object.keys(obj));
//输出:["name", "career"]

3.Object.getOwnProperty

用于返回对象的自有属性,包括可枚举和不可枚举的

console.log(Object.getOwnPropertyNames(obj));
//输出:["name", "career", "age"]

 

posted @   Redchar  阅读(865)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示