全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ES6新特性之数组、Math和扩展操作符用法示例

本文实例讲述了ES6新特性之数组、Math和扩展操作符用法。分享给大家供大家参考,具体如下:

一、Array

Array对象增加了一些新的静态方法,Array原型上也增加了一些新方法。

1.Array.from 从类数组和可遍历对象中创建Array的实例

类数组对象包括:函数中的arguments、由document.getElementsByTagName()返回的nodeList对象、新增加的Map和Set数据结构。

//in ES6中 类数组转换为数组的方法
let itemElements=document.querySelectorAll('.item');
let items=Array.from(itemElements);
items.forEach(function(item){
   console.log(item.nodeType);
});
//in ES5 类数组转换数组的方法
var items=Array.prototype.slice.call(itemElements);

上面的例子中,类数组对象itemElements对象是不具备数组方法forEach()的,但可以通过Array.from()方法转换为Array。

Array.from()另一个特性是它的第二个可选参数mapFunction,该参数允许你通过一次单独调用创建一个新的映射数组:

let navElements=document.querySelectorAll("nav li");
let navTitles=Array.from(navElements,el=>el.textContent);

2.Array.of方法

该方法表现的很像Array的构造函数,它适合只传一个参数的情况,因此Array.of是new Array()的更优选择,所以,构建数组的方式,现在有三种:

let x=new Array(3);// [undefined,undefined,undefined]
let y=Array.of(8);//[8]
let z=[1,2,3];

3.Array的find,findIndex,fill方法

1)find返回回调返回true的第一个元素
2)findIndex返回回调函数返回true的第一个元素的下标
3)fill用所给参数‘覆盖'数组的元素

[5,3,4,10,1].find(n=>n===10);//10
[5,3,4,10,1].findIndex(n=>n===10);//2
[5,3,4,10,1].fill(7);//[7,7,7,7,7]
[5,3,4,10,1].fill(7,1,3);//[5,7,7,7,1]

二、Math

Math对象新增了几个新方法:

//Math.sign返回数字的符号,结果为1、-1或0
   Math.sign(5);//1
   Math.sign(-9)//-1
//Math.trunc 返回无小数位的数字
   Math.trunc(5.9);//5
   Math.trunc(6.8908);//6
//Math.cbrt返回数字的立方根
   Math.cbrt(64);//4

三、扩展操作符

扩展操作符用于特定地方扩展元素,例如:在一个数组中扩展一个数组的元素。

let values=[1,2,4];
let some=[...values,8];//[1,2,4,8]
let more=[...values,8,...values];//[1,2,4,8,1,2,4]

再如  函数调用中的参数中的应用:

let values=[1,2,4];
doSomething(...values);
function doSomething(x,y,z){
  //x=1.y=2,z=4
}
//在ES5中的调用方式
doSomething.apply(null,values);

正如所看到的,该语法使我们免去使用fn.apply()的麻烦,它很灵活,因为扩展操作符可以用在参数列表中的任意位置。

我们已经看到把扩展操作符应用在数组和参数中,事实上,我们可以把它用在所有可比案例的对象中:

let form = document.querySelectorAll('#my-form').
  inputs=form.querySelectorAll('input');
  selects=form.qurySelectorAll('select');
let allTheThings=[form,...inputs,...selects];

现在,allTheThings是一个包含<form>节点、<input>子节点和<select>子节点的二维数组。

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


# ES6  # 新特性  # 数组  # Math  # 扩展操作符  # 浅谈ES6新增的数组方法和对象  # ES6 新增的创建数组的方法(小结)  # ES6中数组array新增方法实例总结  # 详解es6新增数组方法简便了哪些操作  # ES6学习笔记之字符串、数组、对象、函数新增知识点实例分析  # ES6新特征数字、数组、字符串  # ES6数组的扩展详解  # ES6新特性七:数组的扩充详解  # ES6知识点整理之数组解构和字符串解构的应用示例  # ES6新增的数组知识实例小结  # 用在  # 第一个  # 转换为  # 回调  # 增加了  # 是一个  # 几个  # 遍历  # 把它  # 我们可以  # 数据结构  # 可以通过  # 第二个  # 给大家  # 使我  # 可选  # 上也  # 在一  # 不具备  # 很像 


相关文章: 代购小票制作网站有哪些,购物小票的简要说明?  如何在Ubuntu系统下快速搭建WordPress个人网站?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  定制建站策划方案_专业建站与网站建设方案一站式指南  已有域名和空间如何搭建网站?  C#如何使用XPathNavigator高效查询XML  潮流网站制作头像软件下载,适合母子的网名有哪些?  Android自定义listview布局实现上拉加载下拉刷新功能  如何用腾讯建站主机快速创建免费网站?  小建面朝正北,A点实际方位是否存在偏差?  建站之星在线版空间:自助建站+智能模板一键生成方案  免费网站制作appp,免费制作app哪个平台好?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  ,怎么在广州志愿者网站注册?  如何在IIS7上新建站点并设置安全权限?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  Swift中switch语句区间和元组模式匹配  ,网页ppt怎么弄成自己的ppt?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  清除minerd进程的简单方法  常州自助建站费用包含哪些项目?  建站之星客服服务时间及联系方式如何?  建站VPS推荐:2025年高性能服务器配置指南  简历在线制作网站免费,免费下载个人简历的网站是哪些?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  兔展官网 在线制作,怎样制作微信请帖?  制作网站的基本流程,设计网站的软件是什么?  宿州网站制作公司兴策,安徽省低保查询网站?  建站之星如何助力企业快速打造五合一网站?  linux top下的 minerd 木马清除方法  如何制作一个表白网站视频,关于勇敢表白的小标题?  网站制作公司排行榜,四大门户网站排名?  如何高效完成独享虚拟主机建站?  如何解决VPS建站LNMP环境配置常见问题?  如何快速上传建站程序避免常见错误?  教学论文网站制作软件有哪些,写论文用什么软件 ?  存储型VPS适合搭建中小型网站吗?  建站为何优先选择香港服务器?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  实例解析angularjs的filter过滤器  建站之星如何通过成品分离优化网站效率?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  如何快速搭建响应式可视化网站?  如何高效搭建专业期货交易平台网站?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  网站制作软件有哪些,制图软件有哪些?  建站中国官网:模板定制+SEO优化+建站流程一站式指南  焦点电影公司作品,电影焦点结局是什么?  如何在阿里云域名上完成建站全流程? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。