js implements array flattening

js implements array flattening

How to flatten an array

What is array flattening?

Array flattening : refers to converting a multidimensional array into a one-dimensional array.

Example: Flatten the following array.

const arr = [1, [2, 3, [4, 5]]] // ---> [ 1, 2, 3, 4, 5 ]

1. Using flat()

The flat() method was proposed by ES10. It recursively traverses the array at a specified depth and merges all elements with the elements in the traversed sub-array into a new array and returns it. (flat means "horizontal; flat")

const result1 = arr.flat(Infinity) // specifies the depth to be infinite console.log(result1) // [ 1, 2, 3, 4, 5 ]
const result2 = arr.flat(1) // Specify depth as 1
console.log(result2) // [ 1, 2, 3, [ 4, 5 ] ]
const result3 = arr.flat(2) // specifies the depth to be 2
console.log(result3) // [ 1, 2, 3, 4, 5 ]

2. Use regular expressions

The array elements obtained by the following methods will be converted into strings, which is not recommended;

const result1 = JSON.stringify(arr).replace(/\[|\]/g, '').split(',')
console.log(result1) // [ '1', '2', '3', '4', '5' ] Array elements are converted to strings

Optimize the above methods;

const result2 = JSON.parse('[' + JSON.stringify(arr).replace(/\[|\]/g, '') + ']')
console.log(result2) // [ 1, 2, 3, 4, 5 ]

3. Use reduce()+concat()

Use reduce to get the current value and the previous value of the array, determine whether the current value is an array, set the initial value to [], and then use concat to merge the arrays.

  • reduce() method: Executes a reducer function you provide for each element in the array (in ascending order), summarizing the results into a single return value.
  • concat() method: used to merge two or more arrays. This method does not mutate the existing array but returns a new array.
function flatten(arr) {
  return arr.reduce((pre, current) => {
    return pre.concat(Array.isArray(current) ? flatten(current) : current)
  }, [])
}
const result = flatten(arr)
console.log(result) // [ 1, 2, 3, 4, 5 ]

4. Use function recursion

Loop through the array, and recursively process if it contains array elements, and finally convert the array into a one-dimensional array.

const result = []
function exec(arr) {
  arr.forEach(item => {
    if (Array.isArray(item)) {
      exec(item)
    } else {
      result.push(item)
    }
  })
}
exec(arr)
console.log(result) // [ 1, 2, 3, 4, 5 ]

5. Use the spread operator + concat()

The new spread operator introduced in ES6 can reduce the dimension of an array (one dimension at a time), loop to determine whether it contains an array, and perform concat merging.

some() method: Tests whether there is at least one element in the array that passes the provided function test (it returns a Boolean value).

function flatten(arr) {
  while (arr.some(item => Array.isArray(item))) {
    arr = [].concat(...arr)
  }
  return arr
}
const result = flatten(arr)
console.log(result) // [ 1, 2, 3, 4, 5 ]

Summarize

This article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • JS array deduplication details
  • Detailed discussion of several methods for deduplicating JavaScript arrays
  • In-depth study of JavaScript array deduplication problem
  • JavaScript array deduplication solution
  • JavaScript data flattening detailed explanation
  • JavaScript Interview: How to implement array flattening method
  • 5 JavaScript Ways to Flatten Arrays
  • Introduction to JavaScript array deduplication and flattening functions

<<:  Detailed explanation of how to quickly build a blog website using Docker

>>:  Detailed explanation of the setting of background-image attribute in HTML

Recommend

CentOS 7.6 installation of MySQL 5.7 GA version tutorial diagram

Table of contents Environment Preparation Environ...

Tutorial on disabling and enabling triggers in MySQL [Recommended]

When using MYSQL, triggers are often used, but so...

Modify the maximum number of mysql connections and configuration files in docker

1. Find the mysql image docker ps 2. Enter the mi...

Detailed explanation of JavaScript onblur and onfocus events

In HTML pages, visual elements such as buttons an...

Tomcat class loader implementation method and example code

Tomcat defines multiple ClassLoaders internally s...

How to install and configure Redis in CentOS7

Introduction There is no need to introduce Redis ...

Methods for optimizing Oracle database with large memory pages in Linux

Preface PC Server has developed to this day and h...

Detailed explanation of HTML basics (Part 2)

1. List The list ul container is loaded with a fo...

Vue3 draggable left and right panel split component implementation

Table of contents Breaking down components Left P...

This article helps you understand PReact10.5.13 source code

Table of contents render.js part create-context.j...

HTTP Status Codes

This status code provides information about the s...

JS implements dragging the progress bar to change the transparency of elements

What I want to share today is to use native JS to...

Docker case analysis: Building a MySQL database service

Table of contents 1 Create configuration and data...

Listen directive example analysis in nginx

Plot Review In the previous article, we analyzed ...