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

发布时间 - 2026-01-11 00:28:54    点击率:

本文实例讲述了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新增的数组知识实例小结  # 用在  # 第一个  # 转换为  # 回调  # 增加了  # 是一个  # 几个  # 遍历  # 把它  # 我们可以  # 数据结构  # 可以通过  # 第二个  # 给大家  # 使我  # 可选  # 上也  # 在一  # 不具备  # 很像 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 非常酷的网站设计制作软件,酷培ai教育官方网站?  如何用西部建站助手快速创建专业网站?  Python文件流缓冲机制_IO性能解析【教程】  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  米侠浏览器网页背景异常怎么办 米侠显示修复  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  iOS中将个别页面强制横屏其他页面竖屏  如何挑选优质建站一级代理提升网站排名?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  网站制作价目表怎么做,珍爱网婚介费用多少?  如何快速登录WAP自助建站平台?  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  Laravel如何处理和验证JSON类型的数据库字段  Angular 表单中正确绑定输入值以确保提交与验证正常工作  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  Bootstrap整体框架之JavaScript插件架构  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Laravel如何自定义分页视图?(Pagination示例)  如何快速搭建高效WAP手机网站吸引移动用户?  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  网站页面设计需要考虑到这些问题  大连 网站制作,大连天途有线官网?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  Laravel distinct去重查询_Laravel Eloquent去重方法  智能起名网站制作软件有哪些,制作logo的软件?  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  EditPlus中的正则表达式 实战(1)  详解CentOS6.5 安装 MySQL5.1.71的方法  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  Android仿QQ列表左滑删除操作  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  如何快速生成高效建站系统源代码?  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  nodejs redis 发布订阅机制封装实现方法及实例代码  Laravel怎么实现验证码(Captcha)功能  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  Laravel如何使用Blade组件和插槽?(Component代码示例)  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  QQ浏览器网页版登录入口 个人中心在线进入  Laravel如何自定义错误页面(404, 500)?(代码示例)  Laravel如何配置Horizon来管理队列?(安装和使用)  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Python结构化数据采集_字段抽取解析【教程】  高防服务器租用指南:配置选择与快速部署攻略  Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】