最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

关于js类数组的介绍

来源:懂视网 责编:小采 时间:2020-11-27 19:33:25
文档

关于js类数组的介绍

关于js类数组的介绍:js类数组(ArrayLike)是什么?js类数组就是拥有length属性,其它属性(索引)为非负整数(对象中的索引会被当做字符串来处理,这里你可以当做是个非负整数串来理解);不具有数组所具有的方法。例子://类数组示例 var a = {'1':'
推荐度:
导读关于js类数组的介绍:js类数组(ArrayLike)是什么?js类数组就是拥有length属性,其它属性(索引)为非负整数(对象中的索引会被当做字符串来处理,这里你可以当做是个非负整数串来理解);不具有数组所具有的方法。例子://类数组示例 var a = {'1':'

js类数组(ArrayLike)是什么?js类数组就是拥有length属性,其它属性(索引)为非负整数(对象中的索引会被当做字符串来处理,这里你可以当做是个非负整数串来理解);不具有数组所具有的方法。

例子:

//类数组示例
var a = {'1':'gg','2':'love','4':'meimei',length:5};
Array.prototype.join.call(a,'+');//'+gg+love++meimei'//非类数组示例
var c = {'1':2}; //没有length属性就不是类数组

javascript中常见的类数组有arguments对象和DOM方法的返回结果。
比如 document.getElementsByTagName()。

1. 判断一个对象是否是类数组

function isArrayLike(o) { 
if (o && // o is not null, undefined, etc.
 typeof o === 'object' && // o is an object
 isFinite(o.length) && // o.length is a finite number
 o.length >= 0 && // o.length is non-negative
 o.length===Math.floor(o.length) && // o.length is an integer
 o.length < 4294967296) // o.length < 2^32
 return true; // Then o is array-like
 else
 return false; // Otherwise it is not}

2. js类数组转为数组之后进行操作有什么优势

由于类数组不具有数组所具有的操作数组的方法,讲类数组转换为数组之后就能调用如shift,unshift,splice,slice,concat,reverse,sort等这些强大的方法,方便快捷。

3. js类数组转为数组方法

Array.prototype.slice.call(arrayLike)
//将arguments转化为数组后,截取第一个元素之后的所有元素
 var args = Array.prototype.slice.call(arguments,1);

首先Array.prototype.slice.call(arrayLike)的结果是将arrayLike对象转换成一个Array对象。所以其后面可以直接调用数组具有的方法,例如

Array.prototype.slice.call(arrayLike).forEach(function(element,index){ //可以随意操作每一个element了 })

(1)Array.prototype.slice表示数组的原型中的slice方法。注意这个slice方法返回的是一个Array类型的对象。

//slice的内部实现Array.prototype.slice = function(start,end){ 
 var result = new Array(); 
 start = start || 0; 
 end = end || this.length; //this指向调用的对象,当用了call后,能够改变this的指向,也就是指向传进来的对象,这是关键 
 for(var i = start; i < end; i++){ 
 result.push(this[i]); 
 } 
 return result; 
 }

(2)能调用call的只有方法,所以不能用[].call这种形式,得用[].slice。而call的第一个参数表示真正调用slice的环境变为了arrayLike对象。所以就好像arrayLike也具有了数组的方法。

(3)附上js类数组转为数组的通用函数

var toArray = function(s){ 
 try{ 
 return Array.prototype.slice.call(s); 
 } catch(e){ 
 var arr = []; 
 for(var i = 0,len = s.length; i < len; i++){ 
 //arr.push(s[i]); 
 arr[i] = s[i]; //据说这样比push快 } 
 return arr; 
 }

4. 将数组转换为参数列表(类数组)

调用apply方法的时候,第一个参数是对象(this), 第二个参数是一个数组集合, 这里就说明apply的一个巧妙用法,可以将一个数组默认的转换为一个参数列表([param1,param2,param3] 转换为 param1,param2,param3), 这个如果让我们用程序来实现将数组的每一个项,来转换为参数的列表,可能都得费一会功夫,借助apply的这点特性,所以就有了以下高效率的方法。

相关推荐:

js基础数组的概述 数组的长度 数组的遍历

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

关于js类数组的介绍

关于js类数组的介绍:js类数组(ArrayLike)是什么?js类数组就是拥有length属性,其它属性(索引)为非负整数(对象中的索引会被当做字符串来处理,这里你可以当做是个非负整数串来理解);不具有数组所具有的方法。例子://类数组示例 var a = {'1':'
推荐度:
标签: 介绍 js 对象
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top