js 伪数组

简介: js 伪数组

伪数组的定义

类似数组一样,具有索引(下标)和length属性,但不具备数组方法(如push,shift,map等)的对象,被称为伪数组(或类数组)。

伪数组的范例

let fakeArray = {
    length: 3,
    "0": "first",
    "1": "second",
    "2": "third"
};
// 以下形式的对象,也是伪数组
var obj3 = { length: 0 };
var obj4 = { 0: '888', length: 1 };
var obj5 = { 99: 'abc', length: 100 }

伪数组可以使用for进行遍历

for (var i = 0; i < fakeArray.length; i++) {
    console.log(fakeArray[i]);
}

伪数组与数组进行对比

伪数组

fakeArray instanceof Array === false;
Object.prototype.toString.call(fakeArray) === "[object Object]";
Array.isArray(fakeArray) === false;

数组

let arr = [1,2,3,4,6];
arr instanceof Array === true;
Object.prototype.toString.call(arr) === "[object Array]"
Array.isArray(arr) === true;

常见的伪数组

  • 函数的参数列表 arguments
  • DOM 对象列表(如通过 document.getElementsByTags 得到的列表,jQuery中的$("div"))

判断是否为伪数组

// 使用lodash
_.isArrayLike([1, 2, 3]);
// => true
 
_.isArrayLike(document.body.children);
// => true
 
_.isArrayLike('abc');
// => true
 
_.isArrayLike(_.noop);
// => false

伪数组 => 真数组

// 伪数组 —— DOM对象列表
let fakeArr = document.getElementsByTagName('div');

方式一:【ES6】 Array.from() 【推荐】

let realArr = Array.from(fakeArr);

方式二:使用Array.prototype.slice.call()方法

let realArr = Array.prototype.slice.call(fakeArr);

方式三:声明一个空数组,通过遍历伪数组把它们添加到新的数组中

目录
相关文章
|
4天前
|
JavaScript 前端开发 网络架构
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
7 1
|
4天前
|
JavaScript 前端开发 索引
JavaScript编码之路 【JavaScript之操作数组、字符串方法汇总】(三)
JavaScript编码之路 【JavaScript之操作数组、字符串方法汇总】(三)
9 1
|
10天前
|
JavaScript 前端开发
技术经验分享:javaScript遍历对象、数组总结
技术经验分享:javaScript遍历对象、数组总结
10 0
技术经验分享:javaScript遍历对象、数组总结
|
1天前
|
JavaScript
JS 【详解】双指针排序 -- 数组合并后递增排序
JS 【详解】双指针排序 -- 数组合并后递增排序
4 0
|
1天前
|
JavaScript API 索引
JS【详解】Set 集合 (含 Set 集合和 Array 数组的区别,Set 的 API,Set 与 Array 的性能对比,Set 的应用场景)
JS【详解】Set 集合 (含 Set 集合和 Array 数组的区别,Set 的 API,Set 与 Array 的性能对比,Set 的应用场景)
6 0
|
1天前
|
JavaScript 索引
js 类数组 转 数组
js 类数组 转 数组
7 0
|
2天前
|
JavaScript
JS数组操作---删除,arr.pop()方法从数组中删除最后一个元素,并返回该元素的值,arr.shift() 删除第一个值,arr.splice()方法,删除指定元素,arr.splice,从第一
JS数组操作---删除,arr.pop()方法从数组中删除最后一个元素,并返回该元素的值,arr.shift() 删除第一个值,arr.splice()方法,删除指定元素,arr.splice,从第一
|
2天前
|
JavaScript
Js,定义数组的方法,let 数组名 = [数据1,数据2,........,数据n],取值方法,数组名[x],arr[0],let sum sum = sum + arr[0],求和的写法,平均值
Js,定义数组的方法,let 数组名 = [数据1,数据2,........,数据n],取值方法,数组名[x],arr[0],let sum sum = sum + arr[0],求和的写法,平均值
|
3天前
|
JavaScript
js 数组移除指定元素【函数封装】(含对象数组移除指定元素)
js 数组移除指定元素【函数封装】(含对象数组移除指定元素)
4 0
|
4天前
|
前端开发 JavaScript API
前端 JS 经典:数组新增 API
前端 JS 经典:数组新增 API
6 0