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浏览器提速优化设置步骤【方法】

