Home >Web Front-end >Front-end Q&A >How to convert array-like object to array in es6

How to convert array-like object to array in es6

青灯夜游
青灯夜游Original
2023-01-03 14:33:492374browse

Conversion method: 1. Use the "for in" statement to convert the array-like object into an array, the syntax is "for(var i in obj){console.log(arr.push(obj[i])); }"; 2. Use the built-in object keys and values, the syntax "Object.keys(obj)" and "Object.values(obj)"; 3. Use the from() function of the Array object, the syntax "Array.from(obj) ".

How to convert array-like object to array in es6

The operating environment of this tutorial: Windows 7 system, ECMAScript version 6, Dell G3 computer.

#What is an array class?

There are some objects in JavaScript that look like but are not arrays, called array-like objects.

#What is an array-like object?

only contains integers starting from 0 and naturally increasing integers as keys, and also defines length objects used to represent the number of elements. is usually considered to be a -like array object.

  • has a numeric index subscript pointing to the object element, and the length attribute tells us the number of elements in the object;

  • does not have For example, array objects such as push, forEach and indexOf have methods;

Convert class array to array

First method: Use for in to convert an array-like object into an array

<script type="text/javascript">
		var obj = {
			0: &#39;a&#39;,
			1: &#39;b&#39;,
			2: &#39;c&#39;,
		};
		console.log(obj[0]);
		console.log(typeof obj);
		var arr = [];
		for(var i in obj){
			console.log(arr.push(obj[i]));
		}
		console.log(arr);
		//把类数组对象放在一个名为arr的新数组里使得obj变成了数组

		console.log(arr instanceof Array);//判断arr是否为数组

	</script>

How to convert array-like object to array in es6

If you want to get the entire object:

let arr1 = []
		for (let i in obj) {
			let newobj = {}
			newobj[i] = obj[i]
			arr1.push(newobj);
		}
		console.log(arr1);

How to convert array-like object to array in es6

The second method: built-in object keys and values

Built-in object Object.keys: Get the key

Built-in object Object.values ​​gets the value

let obj = {
			&#39;1&#39;: 5,
			&#39;2&#39;: 8,
			&#39;3&#39;: 4,
			&#39;4&#39;: 6
		};
		//内置对象Object.keys:获取键
		var arr = Object.keys(obj)
		console.log(arr);
		//内置对象Object.values获取值
		var arr2 = Object.values(obj)
		console.log(arr2);

How to convert array-like object to array in es6

## The third method: Array.from( )

let obj = {
		&#39;0&#39;: 5,
		&#39;1&#39;: 8,
		&#39;2&#39;: 4,
		&#39;3&#39;: 6,
		&#39;length&#39;:4
	};
	    let arr = Array.from(obj)
		console.log(arr);

Array.from() converts the object into an array and must meet 2 conditions

1: The key must be a numerical value

2: A key-value pair that must have length

When length is not written:

When adding length key-value pairs:

How to convert array-like object to array in es6

##Expand knowledge: the difference between for of, for in and forEach

let arr = [&#39;周一&#39;, &#39;周二&#39;, &#39;周三&#39;, &#39;周四&#39;,&#39;周五&#39;,&#39;周六&#39;,&#39;周日&#39;]
		// for of
		for (let item of arr) {
			console.log(item);
		}
        // for in
		for (let i in arr) {
			console.log(i);
		}
        // forEach
        arr.forEach(item => {
			console.log(item);
		})
The effect is as shown in the figure:


How to convert array-like object to array in es6

for of item represents the array A certain item

i in for in represents the index, which is generally used to traverse the object

The forEach method is used to call each element of the array , and pass the element to the callback function.

for of

1. You can avoid all the traps in

for-in

loops2. You can Using
break, continue and return3.for-of
loops supports more than just array traversal. It is also applicable to many array-like objects4. It also supports string
traversal5.for-of is not suitable for processing original native objects

for in

Note: the for..in loop will traverse the methods and properties in the prototype of a certain type, so this may cause problems in the code Unexpected error

for Each

##1,

foreach

method cannot use return, break, continue statements to jump out Loop 2. The function callback in the forEach method has three parameters:

How to convert array-like object to array in es6 (1) The parameter is the traversed array content ( Required) (2) The parameter is the corresponding array index (optional)

(3) The parameter is the array itself (optional)


3. Execute the provided element once for each element of the array function. Return undefined

[Recommended learning: javascript video tutorial]

The above is the detailed content of How to convert array-like object to array in es6. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn