Heim >Schlagzeilen >Die umfassendste Zusammenfassung von Array-Methoden
var colors = []; var colors = ['red', 'blue'];
if(arr instanceof Array) {}
Wenn die Webseite mehrere Frames enthält, müssen Sie die folgende Methode verwenden, um das Array zu erkennen
if(Array.isArray(arr)) {}
arr.valueOf()
var colors = ['red', 'yellow']; colors.valueOf(); // > ['red', 'yellow']
arr.toString()
var colors = ['red', 'yellow']; colors.toString(); // > "red,yellow"
arr.push(item)
Fügen Sie ein Element vom Ende des Arrays hinzu und kehren Sie zurück die Länge des neuen Arrays
var colors = ['red', 'yellow']; colors.push('pink'); // > 3
arr.pop()
Entfernt das Element vom Ende des Arrays und gibt das gelöschte Element zurück
var colors = ['red', 'yellow']; colors.pop(); // > 'yellow'
arr.unshift(item)
vom Kopf des Arrays. Füge ein Element hinzu und gebe die Länge des neuen Arrays zurück.
var colors = ['green', 'pink']; colors.unshift('pink'); // > 3
arr.shift()
Entferne ein Element vom Kopf des Arrays und das gelöschte Element zurückgeben
var colors = ['yellow', 'orange']; colors.shift(); // > 'yellow'
arr.reverse()
Kehren Sie die Reihenfolge des Arrays um und geben Sie das neu angeordnete Array zurück. Das ursprüngliche Array wird geändert
[1, 2, 3, 'reer', 'game', 2, 5].reverse(); // > [5, 2, "game", "reer", 3, 2, 1]
arr.sort(fn)
Wenn keine Parameter übergeben werden, werden die Elemente im Array standardmäßig zum Vergleich in Zeichenfolgen konvertiert. Daher wird im Allgemeinen nicht empfohlen, die Standardeinstellung arr.sort()
direkt zum Sortieren zu verwenden.
Der Rückgabewert ist das neue Array nach der Sortierung. Das ursprüngliche Array wird geändert
, um die numerischen Elemente im Array von klein nach groß zu sortieren.
var demo = [1, 4, 2, 'reee', 'name', '9', 'doc']; demo.sort(function(a, b)) { return a - b; } // > [1, 2, 4, "reee", "name", "9", "doc"]
Sortieren Sie die numerischen Elemente im Array von groß nach klein
var demo = [1, 4, 2, 'reee', 'name', '9', 'doc']; demo.sort(function(a, b) { return b - a; }) // > [4, 2, 1, "reee", "name", "9", "doc"]
arr.concat(otherArr)
Wenn Sie ein Element oder Array an den Parameter übergeben, wird der Parameter in arr zusammengeführt und das neue Array wird zurückgegeben. Das ursprüngliche Array ändert sich nicht
var arr = [1, 3, 'jake']; arr.concat('rose', [2, 'fi']); // > [1, 3, 'jake', 'rose', 2, 'fi']
arr.slice()
Schneiden Sie das Array aus und geben Sie das Array nach dem Schneiden zurück. Die Elemente ändern sich nicht.
Übergeben Sie einen Parameter, der die Startposition angibt, und die Endposition ist das Ende.
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.slice(2); // > [1, "reee", "name", "9", "doc"]
Übergeben Sie zwei Parameter, die die Startposition und die Endposition angeben, jedoch nicht das Element, in dem sich die Endposition befindet
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.slice(2, 4); // > [1, "reee"]
arr.splice()
Je nach verschiedenen Parametern können Sie Elemente löschen, einfügen bzw. ersetzen, wodurch sich das ursprüngliche Array ändert
Löschen
Übergeben Sie zwei Parameter, die jeweils die Startposition und die Anzahl der zu löschenden Elemente darstellen, und geben Sie ein Array gelöschter Elemente zurück
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.splice(2, 3); // > [1, "reee", "name"] // arr: [4, 2, 1, "9", "doc"]
Einfügen
Übergabe von 3 Parametern, [Startposition |. Die Anzahl der zu löschenden Elemente ist 0 | Das einzufügende Element] Schließlich wird ein Array aus gelöschten Elementen zurückgegeben, da die Anzahl der gelöschten Elemente hier 0 ist, ein leeres Array
var arr = [2, 4, 6]; arr.splice(2, 0, 'red', 'green'); // > [] // arr: [2, 4, "red", "green", 6]
zurückgegeben. >
Übergeben Sie drei Parameter, [Anzahl der zu löschenden Elemente ist 1 |, die eingefügt werden sollen], und geben Sie schließlich ein Array aus gelöschten Elementen zurückvar arr = [2, 4, 9]; arr.splice(1, 1, ['tim', 'tom']); // > [4] // arr: [2, ['tim', 'tom'], 9]Zusammenfassung Daher erreicht diese Methode aufgrund unterschiedlicher Parameter alle Parameter von Anfang bis Ende
arr.indexOf(item)
var arr = [2, 'tim', 4, 5, 2]; arr.indexOf('tim'); // > 1 arr.indexOf('jake'); // > -1
arr.lastIndexOf(item)
var arr = [2, 'tim', 4, 5, 2]; arr.lastIndexOf('tim'); // > 1 arr.indexOf('jake'); // > -1
arr.every()
Führen Sie die angegebene Funktion für jedes Element im Array aus und geben Sie true zurück, wenn die Funktion für eines der Elemente true zurückgibt. Es gibt eine Funktion als Parameter von every. Diese Funktion hat auch 3 Parameter, nämlich [Jedes Element des Arrays, das jeden aufruft|Die Position des entsprechenden Elements|Stellt das Array dar]
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1]; var everyRes = numbers.every(function(item, index, array) { return item > 2; }) // > false
arr.some()
Filtermethode. Gibt ein Array zurück, das aus Elementen besteht, die die Bedingung erfüllen. Die Parameter von fn sind [Jedes Element des Arrays, das jedes | aufruft. Stellt das Array dar] 对数组的每一项进行计算等处理,返回处理结果组成的数组,fn的参数为 遍历数组,没有返回值,fn的参数为 缩减方法。fn的参数为 与reduce一模一样,只是方向相反。 遍历数组或者对象,fn有2个参数,分别为, 比原生的for in 更加健壮 跳过一次循环 终止循环 过滤方法,功能类同原生中的 对每项进行处理,返回处理结果组成的数组,此处fn的参数如下 检测某一个元素item是否存在与数组之中,返回其所在的位置,如果不在,则返回-1 合并数组,会改变第一个参数的数组为合并之后的数组,返回合并之后的数组 过滤DOM数组中重复的元素 将类数组对象转换为数组 将jQuery对象集合恢复成DOM数组 相关推荐:var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
var everyRes = numbers.filter(function(item, index, array) {
return item > 2;
})
// > [ 3, 4, 5, 4, 3 ]
arr.map(fn)
[ 调用every的数组的每一项元素 | 对应元素所在的位置 | 表示该数组 ]var numbers = [1, 2, 3, 3, 2, 1];
var everyRes = numbers.map(function(item, index, array) {
return item > 2;
})
// >[false, false, true, true, false, false]
arr.forEach(fn)
[ 调用every的数组的每一项元素 | 对应元素所在的位置 | 表示该数组 ]numbers.forEach(function(item, index) {
// do something
})
arr.reduce(fn)
[ 前一个元素 | 当前元素,从1开始 | 后一个元素的序列,从1开始计数 | 表示该数组 ]var values = [1, 2, 3, 4, 5];
var sum = values.reduce(function(prev, cur, index, array) {
return prev + cur;
})
// > 15
//每一次迭代之后的结果分别为
// [3, 3, 4, 5]
// [6, 4, 5]
// [10, 5]
// 15
arr.reduceRight(fn)
jQuery相关方法
$.each(arr, fn)
[ 数组的索引或者对象的key值 | 索引或者key值对应的value值 ]var arr = [1, 2, 3];
$.each(arr, function(key, value) {
// do something
});
return | return true
return false
$.grep(arr, fn)
arr.filter(fn)
。此处fn的参数如下
[ value: 对象/数组的值 | key值或者序列 ]var arr = [ 1, 3, 6, 4 ];
$.grep(arr, function(val, key) {
return val >= 3;
});
// > [3, 6, 4]
// arr : [ 1, 3, 6, 4 ] 不会改变
$.map(arr, fn)
[ value: 对象/数组的值 | key值或者序列 ]var arr = [1, 2, 5, 3];
$.map(arr, function(val, key) {
return val * 10;
})
// > [10, 30, 30, 20, 10]
// 原数组不受影响
$.inArray(item, array)
$.inArray(3, [1, 2, 3]);
// > 2
$.merge(arr1, arr2)
var arr = [1, 3, 4];
var arr2 = [4, 3, 1];
$.merge(arr, arr2);
// > [1, 3, 4, 4, 3, 1]
// 为了防止第一个数组被改变,可以使用下面的方式来写
$.merge($.merge([], arr), arr2);
$.unique(arr)
$.makeArray(obj)
$(elem).toArray()