let arrayLike = {
'0': 'a',
'1': 'b',
'2': 'c',
length: 3
};
let arr1 = [].slice.call(arrayLike);
arr1 //['a','b','c']json
分析:
[].slice是一个函数,函数能够调用call方法.
经过call(),认arrayLike具备数组slice方法,而数组slice()会返回数组,间接认arrayLike调用slice()后最终返回数组
假如认call()带上参数如:
let arr2 = [].slice.call(arrayLike, 1, 2); //['b']
与下面这行代码运行结果是同样
let arr3 = ['a','b','c'].slice(1,2) //['b']
能够发现call()的第二参数和第三参数是arrayLike调用slice()时传给slice()的参数数组
那为何arr1结果为['a','b','c'],而不是['a','b']或其它呢?
运行下面代码:
let arr4 = [].slice.call(arrayLike, 0, 0); //['a','b','c']
let arr5 = [].slice.call(arrayLike) //['a','b','c']
经过对比arr4和arr5发现,若是call()不传第二,三参数.js默认都是0,因此会返回['a','b','c']函数
* [].join.call(arrayLike) // a,b,c
结果获得字符串"a,b,c".由于数组join()就是返回字符串.也能够传参
[].join.call(arrayLike, '|') // a|b|c测试
//push(元素)是往数组尾部插入元素
* let arr6 = [].push.call(arrayLike, 'd'); //4
arr6表示arrayLike的长度length
而arrayLike变为 {0: "a", 1: "b", 2: "c", 3: "d", length: 4}.net
* 经过如下四个函数,应该能够间接实现对象作成队列效果.本人暂没详细测试.有机会再深刻下
[].push.call(),
[].pop.call(),
[].unshift.call(),
[].shfit.call()对象
* [].sort.call() 能够认json对象排序.
let arrayLike1 = {
'0': 'c',
'1': 'a',
'2': 'b',
length: 3
};
let arr7 = [].sort.call(arrayLike1); //{0: "a", 1: "b", 2: "c", length: 3}blog
* [].reverse.call() 仍是以arrayLike1为例
let arr8 = [].reverse.call(arrayLike1); //{0: "b", 1: "a", 2: "c", length: 3}排序
* [].concat.call() 传个参数比较明白
let arr9 = [].concat.call(arrayLike1, 'd');
结果为:[{'0': 'c','1': 'a','2': 'b',length: 3}, 'd']队列
* [].splice.call()
let arr10 = [].splice.call(arrayLike1, 1, 1);
arr10结果为 ['a']表示要删除的元素
arrayLike1结果为 {0: "c", 1: "b", length: 2}字符串
* [].indexOf.call()
let arr11 = [].indexOf.call(arrayLike1, 'a') // -1
let arr12 = [].indexOf.call(arrayLike1, 'a') // 1
* [].lastIndexOf.call类上
转载于: