지도 기능: 일대일 데이터 변환
때때로 데이터의 일부를 반환하거나 일관된 작업을 수행하기 위해 데이터를 수정해야 하는 경우가 있는데, 이것이 매핑입니다.
方法 | 返回值 | 一对一 | 对所有元素运行 |
---|---|---|---|
.map((value, index, array) => *) | 数组 | 是 | 是 |
각 입력에 대한 출력을 생성해야 할 때마다 일반적으로 map
가 선호되는 방법입니다. 각 레코드에 대해 작동하는 Map 기능을 허용합니다. 매핑 함수에서 반환된 값은 새 배열의 원래 값과 동일한 위치에 나타납니다.
for 루프에서 .map()으로
.map()
은 기본 for 루프와 완벽하게 작동합니다.
예를 들어 다음 배열의 모든 요소는 대문자로 변환되어야 합니다.
<code class="language-javascript">const data = ['a', 'b', 'c', 'd'];</code>
다음은 몇 가지 구현 방법입니다.
<code class="language-javascript">// 旧的命令式方法 - for 循环 function mapToUpper(data) { const newData = new Array(data.length); for (let i = 0; i < data.length; i++) { newData[i] = data[i].toUpperCase(); } return newData; } // 新的命令式方法 - for...of 循环 function mapToUpper(data) { const newData = []; for (let value of data) { newData.push(value.toUpperCase()); } return newData; } // 新的声明式方法 - .map() const mapToUpper = (data) => data.map(value => value.toUpperCase());</code>
`const newData = new Array(data.length)` 대 `const newData = []`와 같은 일부 변형은 서로 다른 루프 유형에 의해 의무화되지 않고 오히려 일부 역사적 코딩 스타일 차이를 나타냅니다.
`.map()`의 일반적인 용도에는 객체에서 값을 가져오거나 데이터에 대한 일관된 변경 또는 *변환*을 수행하는 것이 포함됩니다.
각각의 큰 기록에서 하나의 정보를 가져와야 하는 경우가 많습니다. `map`은 바로 이것을 위해 설계되었습니다.
<code class="language-javascript">const data = [{ name: 'Alec Berg', roles: ['Creator', 'Executive Producer'], }, { name: 'Bill Hader', roles: ['Creator', 'Executive Producer', 'Actor', 'Director'], }]; // 只需要姓名 data.map((entry) => entry.name); // [ 'Alec Berg', 'Bill Hader' ]</code>
주문 시 직원 할인을 제공해야 한다면 `map`도 가능합니다!
<code class="language-javascript">const cart = [{ itemId: 12345, name: 'shoes', price: 70.00, },{ itemId: 54321, name: 'shirt', price: 15.25, }]; // 应用折扣 const applyDiscount = (discountPercent, order) => { // 首先,获取“剩余”金额。 // 如果折扣为 10%,则乘数为 0.9 const multiplier = 1 - (discountPercent / 100); // 为每个项目创建一个新条目,其中包含折扣后的价格。 // 我们将包含旧价格以供参考。 return order.map((item) => ({ ...item, price: item.price * multiplier, originalPrice: item.price, })); };</code>
여기에는 출력이 제공되지 않습니다. 직접 해보고 싶다면 브라우저 콘솔이나 제가 이 예제를 작성하고 테스트하는 데 사용하는 RunJS와 같은 도구에 붙여넣는 것이 좋습니다.
이것은 데이터 변환의 특별한 버전입니다. "정보 없음"으로 시작하지만 배열을 갖는 행위는 각 항목에 인덱스를 제공하고 인덱스(0부터 시작)에 1을 추가하여 계산 숫자로 변환할 수 있습니다.
`value`(*map* 함수에 제공된 첫 번째 인수)를 사용할 필요는 없지만 두 번째 인수에 액세스하려면 이름을 지정해야 합니다. 밑줄 문자는 유효한 변수 이름이며 이 예와 같이 원치 않는 값을 나타내는 데 자주 사용됩니다.
<code class="language-javascript">const getCountingNumbers = (upTo) => new Array(upTo) // 新数组是“稀疏的”,需要值才能映射 .fill('') // 第二个参数是数组索引。 .map((_, index) => index + 1); getCountingNumbers(5); // [ 1, 2, 3, 4, 5 ]</code>
이것은 `.map()`의 예이지만 새로운 함수인 `Array.from()`도 이 작업을 수행할 수 있습니다.
<code class="language-javascript">const getCountingNumbers = (upTo) => Array.from( // 通过提供具有长度的对象来“伪造”类似数组的对象 { length: upTo }, // 使用与 .map() 相同的映射函数。 (_, index) => index + 1 );</code>
`.map()`을 사용할 때 다른 방법을 논의하는 것이 이상하게 보일 수 있지만, 적어도 위의 예에서는 `Array.from()`이 `.map()`을 호출합니다.
`.map()` 사용 방법을 이해하는 데 도움이 되기를 바랍니다. 데이터 변환은 많은 도구와 산업의 핵심이므로 '.map()'은 많은 프로젝트에서 중요한 부분입니다.
`.map()`에 대해 질문이나 의견이 있으면 기꺼이 논의하겠습니다!
위 내용은 JavaScript 배열: 지도의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!