Recently I was working on a new project, I reviewed the code in my spare time, and found that I used a lot of for loops (simple and clear). Then I looked at others’ code and found that there was almost no FOR in it, and it was almost all foreach and map loops. Am I writing too low? When writing the code also sometimes have actually choose panic disorder, whether should use what kind of circulation, finally found always can’t use other ways, finally always chose the most simple for, how a nice get, also want to spend some time earlier study compare the array of the circulation method, the following start body 😄!!
1. 10 common array traversal methods in ES5
- For loop
- Array.prototype.forEach
- Array.prototype.map
- Array.prototype.filter
- Array.prototype.reduce
- Array.prototype.some
- Array.prototype.every
- Array.prototype.indexOf
- Array.prototype.lastIndexOf
- for… In loop statement
1. For: concise, easy to understand, may need to write more code, define a few more variables, but for my use, I love.
"Regular edition"let arr = [1.2.3.4.5];
for(let i = 0; i < arr.length; i++) {
arr[i] = arr[i] * 2;
}
console.log(arr); //[2, 4, 6, 8, 10]"Upgraded version"let arr = [1.2.3.4.5];
for(let i = 0; len = arr.length,i < len; i++) {
arr[i] = arr[i] * 2;
}
console.log(arr); //[2, 4, 6, 8, 10]
Copy the code
2. The forEach: Receives two parameters, the first parameter is a function of run on each item (with three parameters), the second parameter “optional” is to run the function the scope of the object (affect the value of this), return can’t interrupt function to continue, so there is no return value, does not change the original array, easy to use commonly used instead of the for, But not as high performance as for, and compatibility (IE6-8).
let arr = [1, 2, 3, 4, 5];
arr.forEach((value, index, array) => {
return value * 2;
});
console.log(arr); //[1, 2, 3, 4, 5]
Copy the code
3. Map: The basic usage is the same as foreach, except that it can return the value without changing the original array. It is usually used to modify the array value and map it to a new array.
let arr = [1, 2, 3, 4, 5];
let arrs = arr.map((value, index, array) => {
return value * 2;
});
console.log(arrs); //[2, 4, 6, 8, 10]
Copy the code
4. Filter: As the name implies, “filter”, which means to remove the unwanted values,return true
For the desired value,return false
Is the value removed, usually used to filter an array without changing the original array.
let arr = [1, 2, 3, 4, 5];
let arrs = arr.filter((value, index, array) => {
if (value > 2) {
return true;
} else {
return false; }}); console.log(arrs); / / [3, 4, 5]Copy the code
5. Reduce: An accumulator can be implemented to sum each value of an array (from left to right). The difference is that there are four arguments. Prev represents the sum of the first two values (the first value if no initial value is defined), and next represents the last value.
let arr = [1, 2, 3, 4, 5];
let arrs = arr.reduce((prev, next, index, array) => {
console.log(prev); // 1,3,6,10
console.log(next); // 2,3,4,5
returnprev + next; }); console.log(arrs); / / 15Copy the code
6. Some: Is similar to filter, except that the return value isBoolean
Instead of filtering a new array, it filters if any values match the condition. If any values match the condition, it returns true immediately and does not continue, otherwise it returns false.
let arr = [1, 2, 3, 4, 5];
let arrs = arr.some((value, index, array) => {
return value > 3;
});
console.log(arrs); // true
Copy the code
7. Every: similar to some, except that every value that meets the condition is returned true, otherwise false.
let arr = [1, 2, 3, 4, 5];
let arrs = arr.every((value, index, array) => {
return value > 3;
});
console.log(arrs); //false
let arr = [ 4, 5];
let arrs = arr.every((value, index, array) => {
return value > 3;
});
console.log(arrs); //true
Copy the code
This method is almost the same as that used in a string, except that it does not proceed until it finds a value that meets the criteria, and returns the index that meets the criteria, otherwise -1 is returned.
let arr = [1, 2, 3, 4, 5];
letarrs = arr.indexOf(2); console.log(arrs); / / 1let arr = [1, 2, 3, 4, 5];
let arrs = arr.indexOf(6);
console.log(arrs); // -1
Copy the code
9. LastIndexOf: Similar to indexOf, except that the search direction is from back to front.
let arr = [1, 2, 3, 4, 5, 1];
letarrs = arr.lastIndexOf(1); console.log(arrs); / / 5let arr = [1, 2, 3, 4, 5, 1];
let arrs = arr.lastIndexOf(6);
console.log(arrs); // -1
Copy the code
10. for… In: is used to iterate over objects. In fact, the nature of an array is also based on the key-value pairs of key and value. Array traversal is performed by subscript, and object traversal is performed by key.
let arr = [1, 2, 3, 4, 5];
for(let i inarr) { console.log(i); // 0, 1, 2, 3, 4}let arr = {name: "lewis", age: 25};
for(let i in arr) {
console.log(i); // name, age
}
Copy the code
2. Commonly used in ES6for... of
Array traversal method:
for… Of: JavaScript’s original for… In loop, can only get the key name of the object, not the key value directly. ES6 provided for… An of loop, which allows you to iterate over keys but not objects, is used to loop through arrays.
let arr = [1, 2, 3, 4, 5];
for (let i inarr) { console.log(i); // 0, 1, 2, 3, 4}for (leti of arr) { console.log(i); // 1, 2, 3, 4, 5}Copy the code
Summary: I’m sure you’ve got the basic usage and examples pretty much figured out, so to summarize, the general loop uses for,for… in,for… For of and forEach, map is used to map to a new array, filter is used to filter out desired values, reduce is used to accumulate values, and indexOf and lastIndexOf can be used to find some values and to know the specific location of values. Next is the right medicine, according to local conditions, I believe you will be skilled and accurate application.
3. Common array loops for,for… in,for… Comparison of of and forEach/ Map performance:
let arr = Array(100).fill(5);
console.time("For loop");
for(let i = 0; i < arr.length; i++) {
arr[i] = arr[i] * 2;
}
console.timeEnd("For loop"); // forLoop: 0.041ms console.time("for... In circulation");
for(let i in arr) {
arr[i] = arr[i] * 2;
}
console.timeEnd("for... In circulation"); // for... In loop: 0.126ms console.time("for... Of circulation");
for(let i of arr) {
arr[i] = arr[i] * 2;
}
console.timeEnd("for... Of circulation"); // for... Of loop: 3532.695ms console.time("The forEach loop");
arr.forEach((value, index, arr) => {
arr[index] = value * 2;
});
console.timeEnd("The forEach loop"); // forEach loop: 0.103ms console.time("The map cycle");
arr.map((value, index, arr) => {
arr[index] = value * 2;
});
console.timeEnd("The map cycle"); //map loop: 0.086msCopy the code
If you use the correct method in the right situation and it is simple and effective, it is the best way to use the correct method. In the future, you can use the for loop.
Common methods of checking arrays:
- instanceof
- Array.isArray()
- Object. The prototype. ToString. Call () “it is recommended to use this”
Wonderful preview: recently lasted for two months of big demand encountered a lot of pit, the next will be shared out, with this mutual encouragement 😂
More exciting content welcome to follow my official account [God helps Those who help Themselves Lewis]