> 웹 프론트엔드 > JS 튜토리얼 > 배열 함수의 용도는 무엇입니까?

배열 함수의 용도는 무엇입니까?

小云云
풀어 주다: 2018-02-23 15:53:16
원래의
1668명이 탐색했습니다.
혼란스러울 때가 많을 수 있습니다. reduce를 더 사용해야 하거나 filter를 사용하지 말고 map를 사용해야 합니다. >for, forEach를 사용하면 어떨까요? 너무 혼란스럽지 않나요?
reduce更多或者你不应该使用filter,更应该使用map;或者是for,为什么不使用forEach?是不是太纠结了。

事实上呢?数组和数组的迭代函数对于初学者来说都会感到困惑,所以我将试着为每个简化问题,最后提出的问题是:你想要返回什么?

简介

  • 为每个现有的东西返回一个东西:map()

  • 只返回一些现有的东西:filter()

  • 只返回一个东西:reduce()

  • 不要返回任何东西,而是对每个已存在的东西做一些事情:forEach()

接下来一个个介绍这些数组相关的函数,并且使用一个非箭头函数示例,另外同时用一个箭头函数的示例。

为每个现有的东西返回一个新东西:map()

如果你有一个数组,燕且希望对该数组中的每一项执行一些操作,返回一个带有新值的数组,那么使用map()是最合适不过。这里有一个简单的函数,它接受数组并将数组每个项做翻倍运算:

const originalArray = [1, 2, 3];const newArray = originalArray.map(function(item) {    return item * 2;
});
console.log(newArray); // -> [2, 4, 6]
로그인 후 복사

使用ES6的箭头函数:

const originalArray = [1, 2, 3];const newArray = originalArray.map(item => item * 2);
console.log(newArray); // -> [2, 4, 6]
로그인 후 복사

注意:使用新的箭头函数语法,我们不需要使用functionreturn关键词或者花括号{}。这是因为箭头函数提供了像这样的simple()函数的隐式返回。你可以从Wes Bos阅读更多关于箭头函数的信息。

返回一个新数组,只包含一些符合条件的现有数组项:filter()

filter()可能是最容易理解的数组函数,因为它的命名非常好。filter()接受一系列的值,对每个值执行一个函数或比较,然后返回一个新的数组。这些值通过它的测试(我们称之为truthy值)。

这里有一个示例,从一个数组中取出大于5的数,然后返回一个符合条件的新数组:

const originalArray = [1, 9, 4, 2, 42];const newArray = originalArray.filter(function(item) {    return item > 5;
});
console.log(newArray); // -> [9, 42]
로그인 후 복사

使用ES6的箭头函数:

const newArray = originalArray.filter(item => item > 5);
로그인 후 복사

只返回一个新东西:reduce()

有时候你有一个系列的值,但你只想从它们当中返回一个新东西。数组中的reduce()函数会对数组中的每个项目执行一个函数或比较,然后对所谓的累加器执行一些操作。这是一个更容易用一个例子来描述的函数,因为它描述的术语和函数本身一样让人困惑。

假设你有名字的数组,你想数一下Bob这个名字出现的次数:

const originalArray = ["Alice", "Bob", "Charlie", "Bob", "Bob", "Charlie"];const numberOfBobs = originalArray.reduce(function(accumulator, item) {    if (item === "Bob") {        return accumulator + 1;
    } else {        return accumulator;
    }
}, 0);
console.log(numberOfBobs); // -> 3
로그인 후 복사

使用ES6的箭头函数:

const numberOfBobs = originalArray.reduce((accumulator, item) => {    if (item === "Bob") {        return accumulator + 1;
    } else {        return accumulator;
    }
}, 0);
로그인 후 복사

正如你看到的一样,这个箭头函数并没有节省我们的时间,因为我们必须为函数提供两个参数,然后在返回之前有逻辑,所以我们仍需要花括号{}

reduce()函数末尾的0是我们累加器的开始值,如果我们遇到的值是Bob,则添加1,否则我们将返回当前的累加器。如果你不返回任何东西,那么下一次运行该函数的时候将返回undefined

对数组中每个值做一些事情,但不返回任何值:forEach()

有时,你会有一系列想要处理的值,但不是需要跟踪每个函数调用的返回值。这就是forEach()

사실 위로? 배열과 배열에 대한 반복 함수는 초보자에게 혼란을 줄 수 있으므로 각각에 대한 문제를 단순화하려고 노력할 것이며 마지막 질문은 다음과 같습니다. 무엇을 반환하고 싶습니까?

Introduction

  • 기존 항목마다 하나씩 반환: map()

  • 일부만 반환 기존 항목: filter()

  • 한 항목만 반환: reduce()

  • 반환하지 않음 하지만 기존의 각각에 대해 뭔가를 합니다: forEach()

다음으로 이러한 배열 관련 함수를 하나씩 소개하고 화살표가 아닌 것을 사용하겠습니다. 함수 예제를 사용하고 화살표 함수 예제도 사용합니다. 기존 항목 각각에 대해 새 항목 반환: map()

배열이 있고 배열의 각 항목에 대해 일부 작업을 수행하려면 밴드를 반환하세요. 새 값이 있는 배열의 경우, map()을 사용하는 것이 가장 적합합니다. 다음은 배열을 가져와 각 항목을 두 배로 만드는 간단한 함수입니다.
const originalArray = [1, 2, 3];
originalArray.forEach(function(item) {
    doSomething(item);
});
로그인 후 복사
ES6의 화살표 함수 사용:
originalArray.forEach( item => doSomething(item); );
로그인 후 복사
🎜참고: 새로운 화살표 함수 구문을 사용하면 <코드를 사용할 필요가 없습니다. >function, return 키워드 또는 중괄호 {}. 이는 화살표 함수가 이와 같은 simple() 함수로부터 암시적 반환을 제공하기 때문입니다. Wes Bos에서 화살표 기능에 대해 자세히 알아볼 수 있습니다. 🎜🎜기준을 충족하는 일부 기존 배열 항목만 포함하는 새 배열을 반환합니다. filter()🎜🎜filter()는 아마도 이해하기 가장 쉬운 배열 함수일 것입니다. 이름이 잘 지어졌네요. filter()는 값 목록을 받아 각 값에 대해 함수나 비교를 수행하고 새 배열을 반환합니다. 이러한 값은 테스트를 통과합니다(우리는 이를진실한값이라고 부릅니다). 🎜🎜다음은 배열에서 5보다 큰 숫자를 가져와 조건을 충족하는 새 배열을 반환하는 예입니다. 🎜
arr.map((item, index) => {})
arr.filter((item, index) => {})
arr.reduce((accumulator, item, index) => {})
arr.forEach((item, index) => {})
로그인 후 복사
🎜ES6의 화살표 기능 사용: 🎜rrreee🎜새 항목만 반환합니다. reduce()🎜🎜때때로 일련의 값이 있지만 그 값에서 새로운 것을 반환하고 싶을 때가 있습니다. 배열의 reduce() 함수는 배열의 각 항목에 대해 함수나 비교를 수행한 다음 누산기에 대해 일부 작업을 수행합니다. 이는 설명하는 용어가 함수 자체만큼 혼란스럽기 때문에 예제를 통해 설명하기가 더 쉬운 함수입니다. 🎜🎜이름 배열이 있고 Bob이라는 이름이 나타나는 횟수를 세고 싶다고 가정해 보세요. 🎜rrreee🎜ES6 화살표 함수 사용: 🎜rrreee🎜보시다시피 이 화살표 함수는 함수에 두 개의 매개변수를 제공한 다음 반환하기 전에 논리를 갖춰야 하므로 시간이 절약되지 않습니다. 따라서 여전히 중괄호 {}가 필요합니다. 🎜🎜reduce() 함수 끝에 있는 0은 우리가 발견한 값이 Bob인 경우 누산기의 시작 값입니다. 그런 다음 1을 추가하세요. 그렇지 않으면 현재 누산기를 반환합니다. 아무것도 반환하지 않으면 다음에 함수를 실행할 때 undefine이 반환됩니다. 🎜🎜배열의 각 값으로 작업을 수행하지만 아무것도 반환하지 않습니다: forEach()🎜🎜때때로 처리하고 싶지만 추적할 필요가 없는 일련의 값이 있는 경우가 있습니다. 모든 함수 호출 반환 값. 이것이 forEach()의 의미입니다. 🎜rrreee🎜ES6 화살표 기능 사용: 🎜rrreee🎜요약🎜🎜간단하고 달콤합니다. 다음은 각 기능을 최대한 단순하게 유지하기 위해 제공하는 가장 간단한 예입니다. 이는 주로 언제 사용해야 하는지 더 쉽게 이해할 수 있도록 하기 위한 것입니다. 이러한 함수로 많은 작업을 수행할 수 있으며 각 함수에는 현재 인덱스도 제공하는 고급 형식이 있습니다. 🎜rrreee🎜관련 권장 사항: 🎜🎜🎜연결 테이블 편집을 구현하는 PHP 배열 함수🎜🎜🎜🎜가장 실용적인 JS 배열 함수 구성🎜🎜🎜🎜일반적으로 사용되는 배열 함수는 무엇인가요🎜🎜🎜🎜🎜🎜

위 내용은 배열 함수의 용도는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
이전 기사:자바스크립트 데이터 구조 및 알고리즘에 대한 자세한 설명 다음 기사:JavaScript 생성자에 대한 자세한 설명
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
관련 주제
더>
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿