本文实例讲述了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小时内与您取得联系。