ES6常用小技巧总结【去重、交换、合并、反转、迭代、计算等】


Posted in Javascript onDecember 21, 2019

本文实例讲述了ES6常用小技巧。分享给大家供大家参考,具体如下:

1- 数组去重

var arr = [1,2,3,4,3,4]; 
var arr2 = [...new Set(arr)];

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

2- 交换两个变量的值

let [x,y] = [1,2];
[y,x] = [x,y];
console.log(y);

3- 获取字符串中的某个字符

let arr= "hellomybo";
console.log(arr[3]);

4- 使用箭头函数代替回调函数

ES5的写法

let a1 = [1,2,3].map(function (x) {
  return x * x;
});

ES6 箭头函数写法

let a2 = [1,2,3].map(x => x * x);
console.log(a1,a2);

5- 合并数组

var arr1 = ['a', 'b'];
var arr2 = ['c'];
var arr3 = ['d', 'e'];
// ES5的合并数组
arr1.concat(arr2, arr3);
// [ 'a', 'b', 'c', 'd', 'e' ]
// ES6的合并数组
[...arr1, ...arr2, ...arr3]
// [ 'a', 'b', 'c', 'd', 'e' ]

6- 字符串反转

let str = "12345678900987654321";

原始写法:

str.split('').reverse().join('')

展开写法:

[...str].reverse().join('')

7- 过滤需要的数值 和 获得计算后的数值

过滤:

['a',,'b'].filter(x => true)   // ['a','b']

计算:

let arr = [1,2,3,4].map(x=>x+1);
console.log(arr);

8-数组降维 使用generator迭代器

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);
}

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
通过MSXML2自动获取QQ个人头像及在线情况(给初学者)
Jan 22 Javascript
javascript getElementsByClassName函数
Apr 01 Javascript
javascript格式化日期时间方法汇总
Jun 19 Javascript
js小数运算出现多位小数如何解决
Oct 08 Javascript
基于jQuery实现网页打印功能
Dec 01 Javascript
jQuery原理系列-css选择器的简单实现
Jun 07 Javascript
浅谈js里面的InttoStr和StrtoInt
Jun 14 Javascript
jQuery树形插件jquery.simpleTree.js用法分析
Sep 05 Javascript
Angular.js中$apply()和$digest()的深入理解
Oct 13 Javascript
Vue中使用 setTimeout() setInterval()函数的问题
Sep 13 Javascript
react高阶组件添加和删除props
Apr 26 Javascript
JavaScript Array对象基本方法详解
Sep 03 Javascript
vue中根据时间戳判断对应的时间(今天 昨天 前天)
Dec 20 #Javascript
angularjs模态框的使用代码实例
Dec 20 #Javascript
推荐几个不错的console调试技巧实现
Dec 20 #Javascript
Vue+Node服务器查询Mongo数据库及页面数据传递操作实例分析
Dec 20 #Javascript
node使用request请求的方法
Dec 20 #Javascript
Vue filter 过滤当前时间 实现实时更新效果
Dec 20 #Javascript
使用JavaScript计算前一天和后一天的思路详解
Dec 20 #Javascript
You might like
Excel数据导入Mysql数据库的实现代码
2008/06/05 PHP
PHP 金额数字转换成英文
2010/05/06 PHP
php 中文和编码判断代码
2010/05/16 PHP
Mysql中分页查询的两个解决方法比较
2013/05/02 PHP
php each 返回数组中当前的键值对并将数组指针向前移动一步实例
2016/11/22 PHP
php接口技术实例详解
2016/12/07 PHP
详解thinkphp实现excel数据的导入导出(附完整案例)
2016/12/29 PHP
php使用socket调用http和smtp协议实例小结
2019/07/26 PHP
PHP实现提高SESSION响应速度的几种方法详解
2019/08/09 PHP
有关PHP 中 config.m4 的探索
2020/08/26 PHP
javascript 导出数据到Excel(处理table中的元素)
2009/12/18 Javascript
另一个javascript小测验(代码集合)
2011/07/27 Javascript
JS获得选取checkbox整行数据的方法
2015/01/28 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
2015/02/20 Javascript
分享使用AngularJS创建应用的5个框架
2015/12/05 Javascript
jQuery实现的购物车物品数量加减功能代码
2016/11/16 Javascript
Javascript 对cookie操作详解及实例
2016/12/29 Javascript
Angular4学习教程之HTML属性绑定的方法
2018/01/04 Javascript
vue自定义底部导航栏Tabbar的实现代码
2018/09/03 Javascript
Vue中key的作用示例代码详解
2020/06/10 Javascript
JavaScript中作用域链的概念及用途讲解
2020/08/06 Javascript
Python中常用操作字符串的函数与方法总结
2016/02/04 Python
从零开始学Python第八周:详解网络编程基础(socket)
2016/12/14 Python
python机器学习之贝叶斯分类
2018/03/26 Python
django 开发忘记密码通过邮箱找回功能示例
2018/04/17 Python
Pandas 合并多个Dataframe(merge,concat)的方法
2018/06/08 Python
Python使用paramiko操作linux的方法讲解
2019/02/25 Python
python如何实现单链表的反转
2020/02/10 Python
Pandas —— resample()重采样和asfreq()频度转换方式
2020/02/26 Python
python代码区分大小写吗
2020/06/17 Python
如何基于python实现年会抽奖工具
2020/10/20 Python
Python读取图像并显示灰度图的实现
2020/12/01 Python
意大利专业化妆品品牌:KIKO MILANO
2017/02/01 全球购物
安全目标责任书
2014/07/22 职场文书
人事代理委托书
2014/09/27 职场文书
Vue3 Composition API的使用简介
2021/03/29 Vue.js