Array.prototype 属性表示 Array 构造函数的原型,并允许您向所有Array对象添加新的属性和方法。
/*
如果JavaScript本身不提供 first() 方法,
添加一个返回数组的第一个元素的新方法。
*/
if(!Array.prototype.first) {
Array.prototype.first = function() {
console.log(`如果JavaScript本身不提供 first() 方法,
添加一个返回数组的第一个元素的新方法。`);
return this[0];
}
}
Array实例继承自 Array.prototype 。与所有构造函数一样,您可以更改构造函数的原型对象,以对所有 Array 实例进行更改。例如,可以添加新方法和属性以扩展所有Array对象。这用于 polyfilling, 例如。
鲜为人知的事实:Array.prototype 本身也是一个 Array。
Array.isArray(Array.prototype);
// true
Array.prototype 属性的属性特性: |
|
|---|---|
| writable | false |
| enumerable | false |
| configurable | false |
Array.prototype.constructorArray,表明了所有的数组都是由 Array 构造出来的。Array.prototype.lengthArray.prototype 也是个数组,所以它也有 length 属性,这个值为 0,因为它是个空数组。下面的这些方法会改变调用它们的对象自身的值:
Array.prototype.copyWithin() Array.prototype.fill() Array.prototype.pop()Array.prototype.push()Array.prototype.reverse()Array.prototype.shift()Array.prototype.sort()Array.prototype.splice()Array.prototype.unshift()下面的这些方法绝对不会改变调用它们的对象的值,只会返回一个新的数组或者返回一个其它的期望值。
Array.prototype.concat()Array.prototype.includes() true,否则返回 false。Array.prototype.join()Array.prototype.slice()Array.prototype.toSource() Object.prototype.toSource() 方法。Array.prototype.toString()Object.prototype.toString() 方法。Array.prototype.toLocaleString()Object.prototype.toLocaleString() 方法。Array.prototype.indexOf()Array.prototype.lastIndexOf()在下面的众多遍历方法中,有很多方法都需要指定一个回调函数作为参数。在每一个数组元素都分别执行完回调函数之前,数组的length属性会被缓存在某个地方,所以,如果你在回调函数中为当前数组添加了新的元素,那么那些新添加的元素是不会被遍历到的。此外,如果在回调函数中对当前数组进行了其它修改,比如改变某个元素的值或者删掉某个元素,那么随后的遍历操作可能会受到未预期的影响。总之,不要尝试在遍历过程中对原数组进行任何修改,虽然规范对这样的操作进行了详细的定义,但为了可读性和可维护性,请不要这样做。
Array.prototype.forEach()Array.prototype.entries() Array.prototype.every()true,否则返回 false。Array.prototype.some()Array.prototype.filter()true 的数组元素放进一个新数组中并返回。Array.prototype.find() undefined。Array.prototype.findIndex() -1。Array.prototype.keys() Array.prototype.map()Array.prototype.reduce()Array.prototype.reduceRight()Array.prototype.values() Array.prototype[@@iterator]() values() 方法是同一个函数。在 JavaScript 中,很多的数组方法被故意设计成是通用的。也就是说,那些看起来像是数组的对象(类数组对象),即拥有一个 length 属性,以及对应的索引属性(也就是数字类型的属性,比如 obj[5])的非数组对象也是可以调用那些数组方法的。其中一些数组方法,比如说 join 方法,它们只会单纯的读取当前对象的 length 属性和索性属性的值,并不会尝试去改变这些属性的值。而另外一些数组方法,比如说 reverse 方法,它们会尝试修改那些属性的值,因此,如果当前对象是个 String 对象,那么这些方法在执行时就会报错,因为字符串对象的 length 属性和索引属性都是只读的。
| Specification | Status | Comment |
|---|---|---|
| ECMAScript 1st Edition (ECMA-262) | Standard | Initial definition. |
| ECMAScript 5.1 (ECMA-262) Array.prototype |
Standard | |
| ECMAScript 2015 (6th Edition, ECMA-262) Array.prototype |
Standard |
| Desktop | Mobile | Server | ||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
prototype | Chrome Full support Yes | Edge Full support 12 | Firefox Full support 1 | IE Full support Yes | Opera Full support Yes | Safari Full support Yes | WebView Android Full support Yes | Chrome Android Full support Yes | Edge Mobile Full support Yes | Firefox Android Full support 4 | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android Full support Yes | nodejs Full support Yes |