


This article will introduce to you the usage of the map() method for processing array data and the difference between the map() method and the forEach statement. The content is very detailed. Let’s look at the specific content below.
First let’s take a look at the basic syntax of map()
var array = [ 数组数据 ]; array.map(回调函数);
Map is a method used for array data , a "callback function" can be executed for each element and the result returned as a new array.
In other words, you can perform any operation on each element of the array by writing the process to be executed in this function!
How to use map method to iterate an array?
The following example is an example of using the map method on an array containing numeric data
var items = [1,2,3,4,5]; var result = items.map(function( value ) { return value * 2; }); console.log( result );
The output result is as follows
In this example, the callback function is used to double each element of the array of values "1 to 5".
For this reason, we allocate an array whose result is doubled as the return value of "result", so you can see that the output results become twice as much as themselves.
Initially, it was all about using for statements or while statements to write loops, but using map is very convenient because it can be implemented with a very simple program!
There is also a reduce() method in Analysis on how to use the map() method for array processing in JavaScript that is similar to the map() method. For information about the reduce() method, please refer to this article: How to use reduce in Analysis on how to use the map() method for array processing in JavaScript
For the difference between reduce() and map() methods, please refer to this article: What is the difference between map() and reduce() in Analysis on how to use the map() method for array processing in JavaScript
map( ) and the forEach statement?
map() is similar to the forEach statement, it can operate on arrays in the same way.
Let’s look at a specific example
//forEach [1,2,3].forEach(function( value ) { console.log( value ); }); //map [1,2,3].map(function( value ) { console.log( value ); });
The output results are the same as
Just as you did in this example As you can see, the results obtained by forEach and map are the same.
So, what is the difference between them? The biggest difference is whether they have a return value.
In other words, forEach is just an execution method, and map returns the result as array data after execution.
Let’s look at the example in detail
forEach:
var result = [1,2,3].forEach(function( value ) { return value * 2; }); console.log( result );
The output result is as follows:
The return value of forEach cannot be seen.
map:
var result = [1,2,3].map(function( value ) { return value * 2; }); console.log( result );
The output result is
Array data can be returned as execution result .
map’s callback function
Before we saw that the callback function has only one parameter, but in fact you can use it to have three parameters!
数组数据.map( function( value, index, array ) { });
Value is the value of the array
index is the index number of the array
array is the array currently being processed
For example, in the following example , we will use the parameter index to double the value of the even number
var items = [1,2,3,4,5,6,7,8,9]; var result = items.map( function( value, index, array ) { if( index % 2 !== 0 ) { return value * 2; } else { return value; } }); console.log( result );
The output result is as follows
In addition, map has an error that does not match the original array Function to make any changes to the data, but if you use the third parameter array, you can also change the original data!
var items = [1,2,3,4,5,6,7,8,9]; items.map( function( value, index, array ) { array[index] = value * 2; }); console.log( items );
The output is as follows
#In the past, the "callback function" was specified as the first parameter of "map", but in fact you can specify Any "object" as second argument!
var array = [ 数组数据 ]; //指定对象为第2个参数 array.map( 回调函数, 对象 );
This makes it possible to combine specified arrays and objects for more convenient programming.
For example, in the following example, the food simple object foodList is specified as the second parameter of map.
var foodList = { '苹果': 45, '哈密瓜': 50, '猕猴桃': 60, '草莓': 40 }; 数组.map( function( value ) { }, foodList );
We specify any keyword from the object and return "price".
var foodList = { '苹果': 45, '哈密瓜': 50, '猕猴桃': 60, '草莓': 40 }; var order = ['草莓', '猕猴桃']; var result = order.map( function( value, index, array ) { return this[value]; }, foodList ); console.log( result );
The output is as follows
#In this example, you can see that the key is set in the array order, from which the key is obtained with the key owned in the object matches "price" and returns it as an array.
The above is the detailed content of Analysis on how to use the map() method for array processing in JavaScript. For more information, please follow other related articles on the PHP Chinese website!

Detailed explanation of JavaScript string replacement method and FAQ This article will explore two ways to replace string characters in JavaScript: internal JavaScript code and internal HTML for web pages. Replace string inside JavaScript code The most direct way is to use the replace() method: str = str.replace("find","replace"); This method replaces only the first match. To replace all matches, use a regular expression and add the global flag g: str = str.replace(/fi

Leverage jQuery for Effortless Web Page Layouts: 8 Essential Plugins jQuery simplifies web page layout significantly. This article highlights eight powerful jQuery plugins that streamline the process, particularly useful for manual website creation

So here you are, ready to learn all about this thing called AJAX. But, what exactly is it? The term AJAX refers to a loose grouping of technologies that are used to create dynamic, interactive web content. The term AJAX, originally coined by Jesse J

This post compiles helpful cheat sheets, reference guides, quick recipes, and code snippets for Android, Blackberry, and iPhone app development. No developer should be without them! Touch Gesture Reference Guide (PDF) A valuable resource for desig

jQuery is a great JavaScript framework. However, as with any library, sometimes it’s necessary to get under the hood to discover what’s going on. Perhaps it’s because you’re tracing a bug or are just curious about how jQuery achieves a particular UI

10 fun jQuery game plugins to make your website more attractive and enhance user stickiness! While Flash is still the best software for developing casual web games, jQuery can also create surprising effects, and while not comparable to pure action Flash games, in some cases you can also have unexpected fun in your browser. jQuery tic toe game The "Hello world" of game programming now has a jQuery version. Source code jQuery Crazy Word Composition Game This is a fill-in-the-blank game, and it can produce some weird results due to not knowing the context of the word. Source code jQuery mine sweeping game

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

This tutorial demonstrates how to create a captivating parallax background effect using jQuery. We'll build a header banner with layered images that create a stunning visual depth. The updated plugin works with jQuery 1.6.4 and later. Download the


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SublimeText3 Linux new version
SublimeText3 Linux latest version
