[js] Array.slice和类数组转数组

a.call(b) 相当于把a方法放到b的原型上(实例私有方法)执行

Array.slice的用途

https://juejin.im/post/5b20b8596fb9a01e8d6a47c0
用法一:
slice方法用于提取目标数组的一部分,返回一个新数组,原数组不变。

//取数组切片
arr.slice(start, end);

var arr = [0,1,2];
var arr2 = arr.slice(); // 相当于复制一份,[0,1,2]
var arr3 = arr.slice(0); // 相当于复制一份,[0,1,2]

用法二:
slice方法的一个重要应用,是将类似数组的对象转为真正的数组。

Array.prototype.slice.call({ 0: 'a', 1: 'b', length: 2 })
// ['a', 'b']

Array.prototype.slice.call(document.querySelectorAll("div"));
Array.prototype.slice.call(arguments);
var a = function(){
     console.log(this);                      // 'littledu'
     console.log(typeof this);               //  object, 是String类的一个实例
     console.log(this instanceof String);    //  true
};
a.call('littledu');
console.log(typeof new String('littledu'));

Array.prototype.slice.call原理

https://www.cnblogs.com/littledu/archive/2012/05/19/2508672.html

var a={length:2,0:'first',1:'second'};
Array.prototype.slice.call(a);//  ["first", "second"]

var a={length:2};
Array.prototype.slice.call(a);//  [undefined, undefined] //slice放到a环境里执行

Array.slice实现原理

我们可以大胆猜一下slice的内部实现

Array.prototype.myslice = 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;
};

var arr = [0, 1, 2, 3];
console.log(arr.myslice(1, 3));
console.log(arr.slice(1, 3));

另参考: https://juejin.im/post/5a5a201f5188257345017af1

转载于:https://www.cnblogs.com/iiiiiher/p/9815059.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、付费专栏及课程。

余额充值