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"]

原文地址:https://www.cnblogs.com/xulei1992/p/11856478.html

时间: 2024-08-29 18:27:12

js 数组遍历 对象遍历的相关文章

JS数组与对象的遍历方法大全

本文简单解析各种数组和对象属性的遍历方法: 原生for循环.for-in及forEach ES6 for-of方法遍历类数组集合 Object.key()返回键名的集合 jQuery的$.each() underscore的_.each() 文中的范例基于以下数组和对象. ? 1 2 3 4 5 6 7 8 var arrTmp = ["value1","value2","value3"]; var objTmp = {     aa:"

数组,对象遍历

一.for-in 1.遍历数组: for(item in array) { console.info(array[item]) } item =>下标 2.遍历对象 for(item in obj) { console.info(item); } item =>属性名 二.forEach 1.遍历数组 array.forEach(function(v, i, a) { console.log(i); }); v =>数组的每一项 i =>下标 a =>数组本身 三.for-o

JS对JSON对象遍历输出的时候真的是按照顺序输出吗?

对象的遍历输出并不是按照对象属性定义顺序来的,那么是按照什么规则来的呢,仔细深入研究你会发现,这还跟浏览器有关系,Chrome跟IE是不一样的,所以给出以下结论: Chrome Opera 的 JavaScript 解析引擎遵循的是新版 ECMA-262 第五版规范.因此,使用 for-in 语句遍历对象属性时遍历书序并非属性构建顺序.而 IE6 IE7 IE8 Firefox Safari 的 JavaScript 解析引擎遵循的是较老的 ECMA-262 第三版规范,属性遍历顺序由属性构建的

原创-整理了下常用的js数组 、对象、数字、字符串的操作方法

终于整理好了...主要是一些常用的函数,包含es6和es5的所有常用的,吧一些不常用的全部砍掉,省的大家看的费事.发现这个到博客上面有点乱.给个百度云地址:https://pan.baidu.com/s/1MwMdW5P8IOoyGRYUQ2dBtQ 直接下就可以 字符串方法 : es6 include 返回布尔值,表示是否找到了参数字符串. 第二个参数表示开始搜索位置 startsWith 返回布尔值,表示参数字符串是否在原字符串的头部. 第二个参数表示开始搜索位置 endsWith 返回布尔

js数组和对象

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <style> </style> <body> </body> <script> //定义数组 var data = ['武汉','瑞昌','宜春'];

js 数组和对象的复制

js数组复制可以利用数组的合并方法concat()会返回一个新数组的特征 来实现复制 例如 var a=[1,2,3]; var b= a.concat(); 利用 slice()也可以, 返回的也是一个新数组. 对象的深度复制可以采用自定义回调函数实现 function clone(myObj){ if(typeof(myObj) != 'object') return myObj; if(myObj == null) return myObj; var myNewObj = new Obje

js 数组、对象转json 以及json转 数组、对象

1.JS对象转JSON 方式:JSON.stringify(obj) var json = {"name":"iphone","price":666}; //创建对象: var jsonStr = JSON.stringify(json); //转为JSON字符串 console.log(jsonStr); 2.JS数组转JSON //数组转json串 var arr = [1,2,3, { a : 1 } ]; JSON.stringify(

js 数组与对象的区别

学习javascript的时候,我曾经一度搞不清楚”数组”(array)和”对象”(object)的根本区别在哪里,两者都可以用来表示数据的集合. 比如有一个数组a=[1,2,3,4],还有一个对象a={0:1,1:2,2:3,3:4},然后你运行alert(a[1]),两种情况下的运行结果是相同的!这就是说,数据集合既可以用数组表示,也可以用对象表示,那么我到底该用哪一种呢? 我后来才知道,数组表示有序数据的集合,而对象表示无序数据的集合.如果数据的顺序很重要,就用数组,否则就用对象. 当然,

js 数组转对象 对象转数组

数组转对象 对象转数组 原文地址:https://www.cnblogs.com/xy1996/p/11826740.html