前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ES6常用数组方法

ES6常用数组方法

作者头像
何处锦绣不灰堆
发布2020-05-29 14:40:54
9610
发布2020-05-29 14:40:54
举报
文章被收录于专栏:农历七月廿一

接来写几个我平时在项目使用的最常用的几个优化的方法~

1.数组去重
代码语言:javascript
复制
	var arr = [1,2,3,4,3,4]; 
	var arr2 = [...new Set(arr)];

这个时候arr2就是去重后的数组~

2. 交换两个变量的值
代码语言:javascript
复制
	let [x,y] = [1,2];
	[y,x] = [x,y];
	console.log(y);
3.获取字符串中的某个字符
代码语言:javascript
复制
	let arr= "hellomybo";
	console.log(arr[3]);
4.使用箭头函数代替回调函数

ES5的写法

代码语言:javascript
复制
	 let a1 = [1,2,3].map(function (x) {
	            return x * x;
	 });

ES6 箭头函数写法

代码语言:javascript
复制
	  let a2 = [1,2,3].map(x => x * x);
	
	  console.log(a1,a2);
5.合并数组
代码语言:javascript
复制
	var arr1 = ['a', 'b'];
	var arr2 = ['c'];
	var arr3 = ['d', 'e'];

// ES5的合并数组

代码语言:javascript
复制
	arr1.concat(arr2, arr3);
	// [ 'a', 'b', 'c', 'd', 'e' ]

// ES6的合并数组

代码语言:javascript
复制
	[...arr1, ...arr2, ...arr3]
	// [ 'a', 'b', 'c', 'd', 'e' ]
6.字符串反转
代码语言:javascript
复制
	let str = "12345678900987654321";

原始写法:

代码语言:javascript
复制
	str.split('').reverse().join('')

展开写法:

代码语言:javascript
复制
	[...str].reverse().join('')
7.过滤需要的数值 和 获得计算后的数值

过滤:

代码语言:javascript
复制
	['a',,'b'].filter(x => true)     // ['a','b']    

计算:

代码语言:javascript
复制
	let arr = [1,2,3,4].map(x=>x+1);
	console.log(arr);
8.数组降维 使用generator迭代器
代码语言:javascript
复制
var arr = [1, [[2, 3], 4], [5, 6]];

var flat = function* (a) {
  var length = a.length;
  for (var i = 0; i < length; i++) {
    var item = a[i];
    if (typeof item !== 'number') {
      yield* flat(item);
    } else {
      yield item;
    }
  }
};

for (var f of flat(arr)) {
  console.log(f);
}
9.splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
var arr = new Array(6)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
arr[3] = "James"
arr[4] = "Adrew"
arr[5] = "Martin"

document.write(arr + "<br />")
arr.splice(2,1,"William")
document.write(arr)
输出:
//George,John,Thomas,James,Adrew,Martin
//George,John,William,James,Adrew,Martin
10.置空数组

有时候我们需要清空数组,一个快捷的方法就是直接让数组的 length 属性为 0,就可以清空数组了。

在这里插入图片描述
在这里插入图片描述
11.将数组转换为对象

有时候,出于某种目的,需要将数组转化成对象,一个简单快速的方法是就使用展开运算符号 ...:

在这里插入图片描述
在这里插入图片描述
12.用数据填充数组

在某些情况下,当咱们创建一个数组并希望用一些数据来填充它,这时 .fill()方法可以帮助咱们。

在这里插入图片描述
在这里插入图片描述
13.从数组中删除虚值

在 JS 中,虚值有 false, 0,'', null, NaN, undefined。咱们可以 .filter() 方法来过滤这些虚值。

在这里插入图片描述
在这里插入图片描述
14.从数组中获取随机值

有时我们需要从数组中随机选择一个值。一种方便的方法是可以根据数组长度获得一个随机索引,如下所示

在这里插入图片描述
在这里插入图片描述
15.对数组中的所有值求和

JS 面试中也经常用 reduce 方法来巧妙的解决问题

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018/02/01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.数组去重
  • 2. 交换两个变量的值
  • 3.获取字符串中的某个字符
  • 4.使用箭头函数代替回调函数
  • 5.合并数组
  • 6.字符串反转
  • 7.过滤需要的数值 和 获得计算后的数值
  • 8.数组降维 使用generator迭代器
  • 9.splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目
  • 10.置空数组
  • 11.将数组转换为对象
  • 12.用数据填充数组
  • 13.从数组中删除虚值
  • 14.从数组中获取随机值
  • 15.对数组中的所有值求和
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档