How to flatten an arrayWhat 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 expressionsThe 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()
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
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()
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 ] SummarizeThis 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:
|
<<: Detailed explanation of how to quickly build a blog website using Docker
>>: Detailed explanation of the setting of background-image attribute in HTML
Table of contents Environment Preparation Environ...
When using MYSQL, triggers are often used, but so...
Apache Tomcat is an open source software that imp...
1. Find the mysql image docker ps 2. Enter the mi...
In HTML pages, visual elements such as buttons an...
Tomcat defines multiple ClassLoaders internally s...
Introduction There is no need to introduce Redis ...
Preface PC Server has developed to this day and h...
1. List The list ul container is loaded with a fo...
Table of contents Breaking down components Left P...
Table of contents render.js part create-context.j...
This status code provides information about the s...
What I want to share today is to use native JS to...
Table of contents 1 Create configuration and data...
Plot Review In the previous article, we analyzed ...