Maison >interface Web >js tutoriel >Quelles sont les méthodes de tableau es6 ?
Les méthodes de tableau ES6 incluent : "from()", "of()", "copyWithin()", "fill()", "find()", "findIndex()", "includes()", " entrées()", "clés()", "valeurs()", etc.
L'environnement d'exploitation de ce tutoriel : système Windows 7, ECMAScript version 6, ordinateur Dell G3.
modifie le tableau d'origine | ne modifie pas le tableau d'origine |
---|---|
push, pop | concat |
unshift, changement | join |
sort | slice |
reverse | indexOf(), lastIndexOf() |
splice | forEach |
copy Dans | carte |
remplir | filtre |
certains | |
chaque | |
réduire, réduireDroit | |
comprend | |
finde, findIndex | |
entries(), clés( ), valeurs() |
splice
Syntaxe
arrayObject.splice(index,howmany,item1,...,itemX)
arrayObject.splice(index,howmany,item1,.....,itemX)
var arr = new Array(); arr[0] = "George"; arr[1] = "John"; arr[2] = "Thomas"; arr.splice(2,1); //"George", "John" arr.splice(1,0,"William"); //"George", "William", "John" arr.splice(2,1,"haha"); //"George", "William", "haha"
slice
语法
arrayObject.slice(start,end);
var arr = new Array(); arr[0] = "George"; arr[1] = "John"; arr[2] = "Thomas"; arr.slice(2,1); //[] arr.slice(1,2); //"William" arr.slice(-2,-1); //"William"
将类似数组的对象(比如arguments)转换为真实的数组
Array.prototype.slice.call(arguments);
方法并不会修改原数组
索引方法
indexOf
array.indexOf(searchElement[, fromIndex])
var data = [2, 5, 7, 3, 5]; console.log(data.indexOf(5, "x")); // 1 ("x"被忽略) console.log(data.indexOf(5, "3")); // 4 (从3号位开始搜索)
lastIndexOf
array.lastIndexOf(searchElement[, fromIndex])
var data = [2, 5, 7, 3, 5]; console.log(data.lastIndexOf(5)); // 4 console.log(data.lastIndexOf(5, 3)); // 1 (从后往前,索引值小于3的开始搜索) console.log(data.lastIndexOf(4)); // -1 (未找到)
两个方法在比较第一个参数与数组中的每一项时,会使用全等操作符, 要求必须完全相等,否则返回-1。
迭代方法
每个方法都接受两个参数,第一个参数callback(回调函数,必选),第二个参数是一个可选的上下文参数。
需要注意的是除了forEach()方法,其余的迭代方法中callback需要有return值否则会返回undefined。
forEach
forEach()对数组进行遍历循环,对数组中的每一项运行给定的函数,这个方法没有返回值。
[].forEach(function(value, index, array) { // ... }, [ thisObject]);
[1, 2, 3, 4].forEach(function (item, index, array) { console.log(array[index] == item); // true sum += item; }); alert(sum); // 10 var database = { users: ["张含韵", "江一燕", "李小璐"], sendEmail: function (user) { if (this.isValidUser(user)) { console.log("你好," + user); } else { console.log("抱歉,"+ user +",你不是本家人"); } }, isValidUser: function (user) { return /^张/.test(user); } }; // 给每个人法邮件 database.users.forEach( // database.users中人遍历 database.sendEmail, // 发送邮件 database // 使用database代替上面标红的this ); // 结果: // 你好,张含韵 // 抱歉,江一燕,你不是本家人 // 抱歉,李小璐,你不是本家
map
map()指“映射”,对数组中的每一项运行给定的函数,返回每次函数调用的结果组成的数组。
[].map(function(value, index, array) { // ... }, [ thisObject]);
var data = [1, 2, 3, 4]; var arrayOfSquares = data.map(function (item) { return item * item; }); alert(arrayOfSquares); // 1, 4, 9, 16
filter
filter(),“过滤”,对数组中的每一项运行给定函数,返回满足过滤条件组成的数组。
array.filter(callback,[ thisObject]);
var arr3 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]; var flag = arr3.filter(function(value, index) { return value % 3 === 0; }); console.log(flag); // [3, 6, 9]
every
every(),判断数组中每一项都是否满足所给条件,当所有项都满足条件,才会返回true。
注意: 空数组,则返回true
array.every(callback,[ thisObject]);
var arr4 = [1, 2, 3, 4, 5]; var flag = arr4.every(function(value, index) { return value % 2 === 0; }); console.log(flag); // false
some
some(),判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
注意: 空数组,则返回false
array.some(callback,[ thisObject]);
var arr5 = [1, 2, 3, 4, 5]; var flag = arr5.some(function(value, index) { return value % 2 === 0; }); console.log(flag); // trueNe modifie pas la connexion du tableau d'origine
concat() Deux tableaux ou plus et renvoie le résultat. join() place tous les éléments du tableau dans une chaîne. Les éléments sont séparés par le délimiteur spécifié.
🎜slice() Renvoie les éléments sélectionnés dans un tableau existant 🎜🎜🎜🎜slice🎜🎜🎜Syntaxe🎜🎜arrayObject.slice(start,end);
🎜🎜🎜start Obligatoire. Spécifie où commencer la sélection. Peut être négatif, en comptant à partir de la fin du tableau. 🎜🎜fin facultative. Spécifie où se termine la sélection. S'il n'est pas spécifié, le tableau découpé contient tous les éléments du début à la fin du tableau. Peut être négatif, en comptant à partir de la fin du tableau. 🎜🎜var arr9 = [1, 2, 3, 4]; var sum9 =arr9.reduce(function (total, curr, index, array) { return total * curr; }); console.log(sum9); // 24 var sum9_1 =arr9.reduce(function (total, curr, index, array) { return total * curr; }, 10); console.log(sum9_1); // 240
Convertir des objets de type tableau (tels que des arguments) en tableaux réels🎜🎜ES5 new array🎜🎜🎜🎜index Méthodes : indexOf(), lastIndexOf()🎜🎜Méthodes itératives : forEach(), map(), filter(), some(), each()🎜🎜Méthodes de fusion : réduire(), réduireRight()🎜🎜
Array.prototype.slice.call(arguments);
La méthode ne modifie pas le tableau d'origine🎜🎜🎜Méthode Index🎜🎜🎜🎜🎜indexOf🎜🎜
var arr9 = [2, 45, 30, 80]; var flag = arr9.reduceRight(function (total, curr, index) { return total - curr; }); var flag_1 = arr9.reduceRight(function (total, curr, index) { return total - curr; },200); console.log(flag); // 3 console.log(flag_1); // 43🎜🎜Renvoie la valeur de l'index entier, s'il n'y a pas de correspondance (correspondance stricte), renvoie -1. 🎜🎜fromIndex est facultatif, indiquant que la recherche commence à partir de cette position. Si la valeur par défaut ou le format ne répond pas aux exigences, utilisez la valeur par défaut 0. 🎜🎜
var a = [1,2,3]; Array.isArray(a); //true🎜🎜lastIndexOf🎜🎜
let arrayLike = { '0': 'a', '1': 'b', '2': 'c', length: 3 }; let arr2 = Array.from(arrayLike); // ['a', 'b', 'c']🎜🎜Commencez la recherche à partir de la fin de la chaîne, pas depuis le début. 🎜🎜La valeur par défaut de fromIndex est array.length - 1. 🎜🎜
Array.from(arrayLike, x => x * x); // 等同于 Array.from(arrayLike).map(x => x * x); Array.from([1, 2, 3], (x) => x * x) // [1, 4, 9]
Les deux méthodes utiliseront l'opérateur d'égalité lors de la comparaison du premier paramètre avec chaque élément du tableau. Elles doivent être complètement égales, sinon -1 sera renvoyé.🎜🎜🎜Méthode d'itération🎜🎜🎜🎜Chaque méthode accepte deux paramètres, le premier paramètre est un rappel (fonction de rappel, obligatoire) et le deuxième paramètre est un paramètre de contexte facultatif. 🎜🎜🎜Le premier rappel de paramètre accepte trois paramètres, la valeur de l'élément actuel, l'index de l'élément actuel dans le tableau et l'objet du tableau lui-même. Autrement dit, function(value,index,arr) {}; il convient de noter que la différence par rapport à la méthode encapsulée dans notre jQuery couramment utilisé est le premier paramètre et le deuxième paramètre, c'est-à-dire que l'ordre de l'index et de la valeur est inversé. . 🎜🎜Le deuxième paramètre est un paramètre de contexte facultatif, qui est l'objet de portée qui exécute le premier paramètre de fonction, qui est la valeur pointée par celui-ci dans le rappel mentionné ci-dessus. Si le deuxième paramètre optionnel n'est pas précisé, l'objet global est utilisé à la place (fenêtre dans les navigateurs), voire indéfini en mode strict. 🎜🎜🎜Il convient de noter qu'à l'exception de la méthode forEach(), le rappel dans les autres méthodes d'itération doit avoir une valeur de retour, sinon il renverra undéfini. 🎜🎜🎜forEach🎜🎜🎜forEach() parcourt le tableau et exécute la fonction donnée sur chaque élément du tableau. Cette méthode n'a pas de valeur de retour. 🎜
Array.of(3, 11, 8) // [3,11,8] Array.of(3) // [3]🎜🎜forEach En plus d'accepter un paramètre de fonction de rappel requis, il peut également accepter un paramètre de contexte facultatif (en modifiant le pointeur this dans la fonction de rappel) (le deuxième paramètre). 🎜🎜Si le deuxième paramètre facultatif n'est pas spécifié, l'objet global est utilisé à la place (fenêtre dans le navigateur), voire indéfini en mode strict 🎜🎜
array. copyWithin(target, start = 0, end = this.length);🎜🎜map🎜🎜🎜map() fait référence au "mapping" , s'exécute. la fonction donnée sur chaque élément du tableau et renvoie un tableau des résultats de chaque appel de fonction. 🎜
// 将3号位复制到0号位 [1, 2, 3, 4, 5].copyWithin(0, 3, 4) // [4, 2, 3, 4, 5] // -2相当于3号位,-1相当于4号位 [1, 2, 3, 4, 5].copyWithin(0, -2, -1) // [4, 2, 3, 4, 5]
['a', 'b', 'c'].fill(7); // [7, 7, 7] let arr = new Array(3).fill([]); arr[0].push(5); // [[5], [5], [5]]🎜🎜filter🎜🎜🎜filter(), "filter", exécute la fonction donnée sur chaque élément du tableau et renvoie un tableau qui répond aux conditions du filtre. La fonction de rappel de 🎜
[1, 4, -5, 10].find((n) => n < 0) // -5 [1, 5, 10, 15].find(function(value, index, arr) { return value > 9; }) // 10🎜🎜filter doit renvoyer une valeur booléenne vraie ou fausse. 🎜🎜Tant que la valeur de retour est faiblement égale à == true/false, elle n'a pas besoin de renvoyer === true/false. 🎜🎜
[1, 5, 10, 15].findIndex(function(value, index, arr) { return value > 9; }) // 2🎜🎜every🎜🎜🎜every() détermine si chaque élément du tableau remplit les conditions données. Lorsque tous les éléments remplissent les conditions, true sera renvoyé.
array.every(callback,[thisObject]);
[1, 2, 3].includes(2) // true🎜🎜some🎜🎜🎜 some(), Détermine s'il y a des éléments dans le tableau qui remplissent les conditions. Tant qu'un élément remplit les conditions, true sera renvoyé.
array.some(callback,[thisObject]);
🎜for (let index of ['a', 'b'].keys()) { console.log(index); } // 0 // 1 for (let elem of ['a', 'b'].values()) { console.log(elem); } // 'a' // 'b' for (let [index, elem] of ['a', 'b'].entries()) { console.log(index, elem); } // 0 "a" // 1 "b"🎜🎜🎜Méthode de fusion🎜🎜🎜
这两个方法相比前面可能稍微复杂一些,它们都会迭代数组中的所有项,然后生成一个最终返回值。这两个方法接收两个参数。
reduce
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。 reduce() 对于空数组是不会执行回调函数的。
array. reduce(function(total, currentValue, currentIndex, array) {<br> // ...<br>});
var arr9 = [1, 2, 3, 4]; var sum9 =arr9.reduce(function (total, curr, index, array) { return total * curr; }); console.log(sum9); // 24 var sum9_1 =arr9.reduce(function (total, curr, index, array) { return total * curr; }, 10); console.log(sum9_1); // 240
reduceRight
reduceRight()和reduce()相比,用法类似,差异在于reduceRight是从数组的末尾开始实现的。
array.reduceRight(callback,[ thisObject]);
var arr9 = [2, 45, 30, 80]; var flag = arr9.reduceRight(function (total, curr, index) { return total - curr; }); var flag_1 = arr9.reduceRight(function (total, curr, index) { return total - curr; },200); console.log(flag); // 3 console.log(flag_1); // 43
Array方法
isArray
判断参数是否是”Array”返回true或false。
var a = [1,2,3]; Array.isArray(a); //true
Array方法
Array.from()
用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)。
let arrayLike = { '0': 'a', '1': 'b', '2': 'c', length: 3 }; let arr2 = Array.from(arrayLike); // ['a', 'b', 'c']
Array.from还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理后的值放入返回的数组。
Array.from(arrayLike, x => x * x); // 等同于 Array.from(arrayLike).map(x => x * x); Array.from([1, 2, 3], (x) => x * x) // [1, 4, 9]
Array.of()
用于将一组值,转换为数组。
Array.of(3, 11, 8) // [3,11,8] Array.of(3) // [3]
实例方法
会改变原数组
copyWithin()
在当前数组内部,将指定位置的成员复制到其他位置(会覆盖原有成员),然后返回当前数组。
array. copyWithin(target, start = 0, end = this.length);
// 将3号位复制到0号位 [1, 2, 3, 4, 5].copyWithin(0, 3, 4) // [4, 2, 3, 4, 5] // -2相当于3号位,-1相当于4号位 [1, 2, 3, 4, 5].copyWithin(0, -2, -1) // [4, 2, 3, 4, 5]
fill()
使用给定值,填充一个数组。
['a', 'b', 'c'].fill(7); // [7, 7, 7] let arr = new Array(3).fill([]); arr[0].push(5); // [[5], [5], [5]]
不会改变原数组
find()
用于找出第一个符合条件的数组成员。它的参数是一个回调函数,所有数组成员依次执行该回调函数,直到找出第一个返回值为true的成员,然后返回该成员。如果没有符合条件的成员,则返回undefined。
find方法的回调函数可以接受三个参数,依次为当前的值、当前的位置和原数组。
[1, 4, -5, 10].find((n) => n < 0) // -5 [1, 5, 10, 15].find(function(value, index, arr) { return value > 9; }) // 10
findIndex()
findIndex方法的用法与find方法非常类似,返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回-1。
[1, 5, 10, 15].findIndex(function(value, index, arr) { return value > 9; }) // 2
includes()
返回一个布尔值,表示某个数组是否包含给定的值。
[1, 2, 3].includes(2) // true
entries(),keys() 和 values()
ES6提供了三个新方法:entries()、keys()和values(),用来遍历数组。它们都返回一个遍历器对象,可以用for...of循环进行遍历,唯一的区别是keys()是对数组的键名的遍历、values()是对数组键值的遍历,entries()方法是对数值的键值对的遍历。
for (let index of ['a', 'b'].keys()) { console.log(index); } // 0 // 1 for (let elem of ['a', 'b'].values()) { console.log(elem); } // 'a' // 'b' for (let [index, elem] of ['a', 'b'].entries()) { console.log(index, elem); } // 0 "a" // 1 "b"
如果不使用for...of循环,可以手动调用遍历器对象的next方法,进行遍历。
let letter = ['a', 'b', 'c']; let entries = letter.entries(); console.log(entries.next().value); // [0, 'a'] console.log(entries.next().value); // [1, 'b'] console.log(entries.next().value); // [2, 'c']
【推荐学习:javascript高级教程】
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!