8个JavaScript数组操作必须熟练运用的方法
手动敲的,拿来收藏。。
<!-- 地址:https://mp.weixin.qq.com/s/DKRk0DU5auqgn_ogmx5g_w -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>8个JavaScript数组操作必须熟练运用的方法</title>
<script>
/*
*JavaScript提供了大量不同的处理数组的方法
*/
/*
*1.Array.map()
使用.map()方法,可以创建一个基于原始数组的修订版数组,.map()方法接受一个
函数,该函数遍历数组中的所有项并进行相应的修改。
当需要更新数组中的所有项并将其存储到一个新数组中, .map()方法就可以派上用场了。
*
*/
// 如有个一文章列表的数组:
const articles = [
{
article_id: "6976209276364652558",
title: "如何在 vue 的计算属性中传递参数",
views: 1258,
},
{
article_id: "6976113133358153736",
title: "Angular数据状态管理框架:NgRx/Store",
views: 2258,
},
{
article_id: "6975722363241365534",
title: "Angular管道PIPE介绍",
views: 1568,
},
];
// 现在基于上面文章列表数组,获取所有title组成的数组,如下:
const arrayTitles = articles.map((item) => item.title);
console.log(arrayTitles);
// [
// '如何在 Vue 的计算属性中传递参数',
// 'Angular数据状态管理框架:NgRx/Store',
// 'Angular管道PIPE介绍'
// ]
// 只要是数组都可以使用.map()。接下来就基于上面标题数组,增加作者信息,如下:
const arrayTitlesWithAuthor = arrayTitles.map(
(title) => `《${title}》作者:天行无忌`
);
console.log(arrayTitlesWithAuthor);
//输出结果如下:
// [
// '《如何在 Vue 的计算属性中传递参数》作者:天行无忌',
// '《Angular数据状态管理框架:NgRx/Store》作者:天行无忌',
// '《Angular管道PIPE介绍》作者:天行无忌'
// ]
// .map()方法是一个用来创建新数组,修改其内容并保持原始数组不变的通用方法。
// 当出现需要修改现有数组的内容并将结果存储为新变量的时候就可以用
/*
*2.Array.filter()
*
* filter()方法根据特定条件获取数组中的元素,像.map()方法一样,它将返回一个新数组
* 并保持原始数组不变。
*
* 基于上面的articles数组,分别获取views小于2000的和大于2000的文章列表
* */
const lessArticles = articles.filter((item) => item.views < 2000);
const muchArticles = articles.filter((item) => item.views > 2000);
console.log(lessArticles);
console.log("\r\n==========================================\r\n");
console.log(muchArticles);
//输出的结果如下:
// [
// {
// article_id: '6976209276364652558',
// title: '如何在 Vue 的计算属性中传递参数',
// views: 1258
// },
// {
// article_id: '6975722363241365534',
// title: 'Angular管道PIPE介绍',
// views: 1568
// }
// ]
// // ==========================================
// [
// {
// article_id: '6976113133358153736',
// title: 'Angular数据状态管理框架:NgRx/Store',
// views: 2258
// }
// ]
// 当需要从数组中删除不符合特定条件的元素时,可以使用.filter()
/*
*3.Array.find()
.find() 方法看起来很像.filter()方法,跟.filter()方法一样,
将匹配的条件的元素返回,区别在于.find()将只返回与提供的条件
匹配的第一个元素,不是数组
**/
const lessArticle = articles.find((item) => item.views < 2000);
const muchArticle = articles.find((item) => item.views > 2000);
console.log(lessArticle);
console.log("\r\n==========================================\r\n");
console.log(muchArticle);
//输出结果:
// {
// article_id: '6976209276364652558',
// title: '如何在 Vue 的计算属性中传递参数',
// views: 1258
// }
// ==========================================
// {
// article_id: '6976113133358153736',
// title: 'Angular数据状态管理框架:NgRx/Store',
// views: 2258
// }
// 什么时候使用Array.find() 呢?当需要获取数组通过定义条件的第一个元素时
/*
*4. Array.forEach()
.forEach() 方法的工作方式很像常规的 for 循环,遍历一个数组
并在每个元素上执行一个函数。.forEach() 的第一个参数是回调函数,它包含循环数组的当前值和索引。
**/
articles.forEach((item, index) => {
console.log(`文章索引 ${index} 的标题为《${item.title}》`);
});
// 输出结果如下:
// 文章索引 0 的标题为《如何在 Vue 的计算属性中传递参数》
// 文章索引 1 的标题为《Angular数据状态管理框架:NgRx/Store》
// 文章索引 2 的标题为《Angular管道PIPE介绍》
// 当需要简单地遍历数组的每个元素而不是需要构建新数组时
/*
*5. for...of
***/
// for...of 是es6推出的迭代器,号称最简洁,可以是用 break,continue和 return 终止循环。跟 .forEach() 不同的是,不提供数组索引。跟 for 语句相比代码少得多,更简洁。
// 下面代码遍历输出数组,如下:
for(const item of articles){
console.log(item);
}
/*
*6.Array.every()
.every()方法将检查数组中的每个元素是否都通过提供的条件,如果数组中的所有元素都通过条件,则将返回 true ,如果没有,将返回 false。
*
* **/
// 例如,检查 articles 数组所有的文章 views 都超过 1000,如下:
const isMoreThan1000 = articles.every((item) => item.views > 1000);
console.log(isMoreThan1000); // true
// 检查 articles 数组所有的文章 views 都超过 2000,如下:
const isMoreThan2000 = articles.every((item) => item.views > 2000);
console.log(isMoreThan2000); // false
// **什么时候使用 Array.every() ?**当需要确认数组的每一项都通过定义的条件时。
/*
*7.Array.some()
.some() 方法和 .every() 方法类似,但验证的结果是相反的,如果数组中的所有元素只要有一个通过条件,则将返回 true ,如果所有的元素都不通过条件,将返回 false。
**/
// 例如,检查 articles 数组所有的文章 views 是否有 views 超过 2000 的文章,如下:
const isMore2000 = articles.some((item) => item.views > 2000);
console.log(isMore2000); // true
// 检查 articles 数组所有的文章 是否有 views 超过 3000 的文章,如下:
const isMore3000 = articles.some((item) => item.views > 3000);
console.log(isMore3000); // false
/*
*8.Array.reduce()
.reduce() 方法接受一个回调函数作为其第一个参数,一个可选的初始值作为其第二个参数。
如果没有提供初始值,则使用第一个数组元素作为值。回调函数提供一个累加器 accumulator 和 currentValue 参数,用于执行 reduce 计算。
*/
//这里就简单举个例子,对 articles 数组的 views 进行累加求和:
const sumViews = articles.reduce(
(accumulator, current) => accumulator + current.views,
0
);
console.log(sumViews); // 5084
// 使用 .reduce() 方法可以用于展平一个数组,当然已经有很多方法可以做到这一点,这就是其中的方法之一。
const flattened = [
[0, 1],
[2, 3],
[4, 5],
].reduce((accumulator, current) => accumulator.concat(current), []);
console.log(flattened); // [ 0, 1, 2, 3, 4, 5 ]
//当需要通过操作其值将数组向下转换为单个值时,可以使用 .reduce() 方法
/*
*9.复制一个对象
*/
let curRow = Object.assign({}, row);// 复制row行对象并赋给curRow
</script>
</head>
<body>
</body>
</html>
“fool me once,shame on you. fool me twice, shame on me.”,翻译过来的意思是“愚弄我一次,是你坏;愚弄我两次,是我蠢”。