浅谈Array.prototype.slice.call(arguments,0)

在谈论这个问题之前 我们先了解下call的用法及作用

对象.方法.call(obj[,arg1[, arg2[,   [,.argN]]]]]):调用一个对象的一个方法,以另一个对象替换当前对象。

 1 function Personal(a){
 2 
 3   this.name = a;
 4 
 5   this.say = function(){
 6 
 7     alert(a)
 8   }
 9 
10 }
11 
12 function Man(a){
13     
14     this.sex = "maie";
15     Personal.call(this,a)
16     
17 }
18 var oa = new Man("oa");
19 oa.say();
View Code

此处将Person的属性继承到了Man上 Man中的Person.call(this)中将Person中的this指向重新定向到
了Man上;

接着我么就来看下 数组的slice方法;

定义和用法

slice() 方法可从已有的数组中返回选定的元素。

语法

arrayObject.slice(start,end)
参数描述
start必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

返回值

返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

 

个人理解

此处的Array.prototype.slice.call(arguments);是将arguments转化成相应的数组;

如何转化的关键应该就在于slice这个方法中;

我们可以这么理解 slice方法;

 1 Array.prototype.slice = function(start,end){
 2       var self = this,len = self.length;
 3       start = start?start<0?start+len:start:0;
 4       end = end ? end<0?end+len:end : len ;
 5       var arr = [];
 6       // console.log(start,end)
 7       for(var i=start;i<end;i++){
 8          arr.push(self[i]);
 9       }
10       return arr;
11 }

这个当中this指向的是Array数组是有length属性的 它就能执行下方的循环操作 ;而此处的Array.prototype.slice.call(arguments,0)调用的slice方法他的this指向的是类数组的arguments;它同样具有length属性;所以 可以将函数中的参数集合转化成数组格式;

 

由此可以衍生出的Array.prototype.slice.call({0:1,1:2,2:3,length:3},0)  ==>[1,2,3]

Array.prototype.slice.call({0:1,3:3,length:4},0)  ==>[1, undefined × 2, 3]||[1, undefined , undefined , 3];

等类数组转化成数组的方式

转载于:https://www.cnblogs.com/tadini/p/5275095.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: array.prototype.slice.call()是一种将类数组对象转换为数组的方法。它通过调用Array原型上的slice方法,并将类数组对象作为其上下文来实现。这个方法可以用于将一些类似数组的对象(比如arguments对象)转换为真正的数组,以便于进行数组操作。 ### 回答2: array.prototype.slice.call()是JavaScript中的一个方法,用于将类数组对象(如arguments对象)转换为真正的数组。 array.prototype.slice是数组的一个内置方法,用于从已有的数组中返回选定的元素。这个方法通常用于截取数组中的一部分元素创建一个新的数组,不会对原数组产生影响。 而调用call()方法将slice方法中的this指向传入的对象。由于类数组对象并不具有slice方法,因此需要通过这种方式将slice方法应用在类数组对象上。 使用array.prototype.slice.call()方法,可以将类数组对象转换为真正的数组。它的工作原理是通过在调用slice方法时将类数组对象作为this参数传入,使得slice方法可以在类数组对象上正确地运行并返回一个新的数组。 使用array.prototype.slice.call()方法的一个常见场景是将类数组对象转换为真正的数组以方便进行数组操作,例如使用数组的forEach、map等方法进行遍历或处理。另外,使用该方法还可以将字符串转换为数组,因为字符串也是类数组对象。 总结来说,array.prototype.slice.call()是将类数组对象转换为真正的数组的一种常用方法,它通过在调用slice方法时将类数组对象作为this参数传入,使得slice方法可以正确地运行并返回一个新的数组。 ### 回答3: array.prototype.slice.call() 是一种将类数组对象(array-like object)转化为真正的数组的方法。类数组对象是指具有与数组类似的结构,但却不是真正的数组,比如 arguments 对象,DOM 元素集合等。 array.prototype.slice.call() 的作用是将类数组对象转化为数组,并返回一个新的数组。该方法利用了 Array.prototype.slice() 方法,将其绑定到类数组对象上,然后调用该方法进行数组转化。由于 slice() 方法可以接收参数来指定切片的起始和结束位置,所以可以将整个类数组对象拷贝到新的数组中。 具体来说,使用 array.prototype.slice.call() 的步骤如下: 1.在类数组对象上调用 call() 方法,并将 Array.prototype.slice() 方法作为该方法的参数; 2.通过该调用,将类数组对象绑定到 Array.prototype.slice() 方法上,使其成为该方法的执行环境; 3.执行 Array.prototype.slice() 方法,将类数组对象转化为数组,并返回新的数组。 例如,我们可以使用 array.prototype.slice.call(arguments) 将函数参数对象 arguments 转化为数组。 需要注意的是,array.prototype.slice.call() 方法只能将具有索引属性(index property)的类数组对象转化为数组,而不能转化不具有索引属性的对象。 总之,array.prototype.slice.call() 是一种将类数组对象转化为数组的常用方法,可以方便地处理一些本应使用数组操作的对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值