ES6(三)数组的扩展
1、Array.form
ES6中,Array.from = function(items,mapfn,thisArg) { }
Array.from 用于将 类数组 和 可遍历对象(实现了Iterator接口的对象以及set、map)对象,转换成真正的数组。
(1) 第一个参数:items,类数组 和 可遍历对象。
在ES5中,将类数组转换成真正数组,如下:
var arr=[].slice.call(likeArray);
实际应用中,类数组对象常常包括 NodeList集合,以及 函数参数 arguments.
(2) 第二个参数,类似map方法,可以直接改变原数组的值。
如下:将 类数组中的值加 1
Array.from(arrayLike, (x)=>x+);
(3) 第三个参数,绑定this。
(4) Array.from 可以将只要原始的数据结构(string,number 等),会先对值进行处理,
然后转换成规范的数组结构,进而可以使用Array中的方法。
Array.from( { length:}, ()=>'jack');
将字符串转换为数组,能正确处理各种Unicode字符,避免 将大于 \uFFFF 的字符,算成两个字符。
function countString(string){
return Array.from(string).length;
}
2、Array.of
Array.of = function(items) { }
用于将一组值,转换成数组,用于弥补Array()不足。
比如:使用 Array(3),指定了数组为3,值为[undefined*3],当参数count>=2时,才会返回新数组。
ES5中可以如下代替:
function ArrayOf(){
return [].slice.call(arguments);
}
3、扩展运算符 ( ... )
扩展运算符背后调用的是遍历器接口(Symbol.iterator),如果A对象没有实现此接口,则无法转换。
[...数据结构A] 这样的书写方式可以将某些数据结构转换成为数组。
扩展运算符 无法将类数组转换为 real Array.
4、数组实例的扩展
(1)copyWithin()
Array.prototype.copyWithin = function(target,start,enf) {}
1、在当前数组内部,将指定位置的成员复制到其他位置,且覆盖原有成员;
2、其中 包括start,不包括enf(end from),如果[1,3,5],即将 3,4位置的元素替换 arr
3、start,endf为负数,则表示数组倒数位数
[, , , , , ].copyWithin(, , ); //[0,1,3,3,4,5]
(2)find() and findIndex()
Array.prototype.find = function(predicate,thisArg) {}
find() 用于找出第一个符合条件的数组成员,参数是一个回调函数,所有数组成员依次执行该回调函数,若无符合条件,则返回undefined。
findIndex() 则返回第一个符合条件的成员的位置,未找到,则返回 -1。
let personList = [
{
name: 'jack',
age:
},
{
name: 'Tom',
age:
},
{
name: 'Lily',
age:
}
]; personList.find((item,index,arr)
=>(item.age < ));
这两个方法都可以发现 NaN,弥补了数组 IndexOf方法的不足。
[NaN].findIndex(y=>Object.is(NaN,y)) //
(3) fill()
Array.prototype.fill = function(value,start,end) {}
使用给定值,填充一个数组。
['a','b','c'].fill(,,);//[a,7,c]
(4)entries(),keys(),values()
var arr = ['key1', 'key2'];
for (let index of arr.keys) { }
如果不使用for...of循环,可以手动调用遍历器对象的next方法,进行遍历。
(5)includes()
String.prototype.includes = function(searchString,position) {};
表示某个数组是否包含给定的值
position 表示搜索的起始位置,负数为倒数位置
indexOf 内部使用严格相当运算符(===)进行判断,这会导致对NaN的误判。
[, , ].includes(, );
[NaN].indexOf(NaN); //-1
[NaN].includes(NaN); //true
Map 的has方法,用来查找 键名。
Set 的has方法,用来查找 值。
(5)数组的空位
数组的空位,是指某一个位置没有任何值,空位不是undefined。
1、forEach,filter,every,some 都会跳过空位。
2、map会跳过空位,但会保留这个值。
3、join 、toString 会将空位视为 undefined,undefined和null 则被处理成空字符串。
而Array.from 会将数组的空位 转换为 undefined,不会忽略这个空位。
( ... )也会转换为 undefined。 至于为什么会出现 空位,我也不太明白。
ES6(三)数组的扩展的更多相关文章
- ES6对数组的扩展(简要总结)
文章目录 数组的扩展(ES6) 1. 扩展运算符 2. Array.from 3. Array.of() 4. copyWithin() 5. find() 和 findIndex() 6. fill ...
- ES6 之 数组的扩展
ES5 检测数组 let arr = [1,2,3,4] Array.isArray(arr) arr instanceof Array 转换方法 arr.toLocaleString() arr.t ...
- ES6对数组的扩展
ECMAScript6对数组进行了扩展,为数组Array构造函数添加了from().of()等静态方法,也为数组实例添加了find().findIndex()等方法.下面一起来看一下这些方法的用法. ...
- 【ES6】数组的扩展——扩展运算符
1.扩展运算符[三个点(...)将一个数组转为用逗号分隔的参数序列] 作用:用于函数调用 function add(x, y) { return x + y; } const numbers = [2 ...
- 【ES6】数组的扩展
1.Array.from(): 将伪数组对象和遍历的对象转为真数组 如果一个对象的键都是正整数或者0,并且有 Length属性,那么这个对象很想数组,称它为伪数组. 伪数组: let obj = { ...
- ES6学习(三):数组的扩展
chapter08 数组的扩展 8.1 扩展运算符 8.1.1 扩展运算符的含义 ... 如同rest运算符的逆运算,将一个数组转换为用逗号分隔的参数序列. console.log(...[1, 2, ...
- 数组的复制及ES6数组的扩展
一.数组的复制 // alert([1,2,3]==[1,2,3]); let cc = [0,1,2]; let dd = cc; alert(dd==cc);//此时改变dd会影响cc ES5 只 ...
- es6数组的扩展
数组扩展运算符 ...(三个点) const demoArr=[0,1,2,3,4] console.log(...demoArr) // 0 1 2 3 4 // 他把一个数组用逗号分隔了出来 // ...
- ES6的新特性(8)——数组的扩展
数组的扩展 扩展运算符 含义 扩展运算符(spread)是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. console.log(...[1, 2, 3]) / ...
- ES6中数组和对象的扩展运算符拷贝问题以及常用的深浅拷贝方法
在ES6中新增了扩展运算符可以对数组和对象进行操作.有时候会遇到数组和对象的拷贝,可能会用到扩展运算符.那么这个扩展运算符到底是深拷贝还是浅拷贝呢? 一..使用扩展运算符拷贝 首先是下面的代码. le ...
随机推荐
- 使用PowerApps快速构建基于主题的轻业务应用 —— 入门篇
作者:陈希章 发表于 2017年12月12日 前言 在上一篇文章 基于Office 365的随需应变业务应用平台 中我提到,随着随需应变的业务需要,以及技术的发展,业务应用的开发的模式也有了深刻的变化 ...
- 小白的Python之路 day1
Python之路,Day1 - Python基础1 本节内容 Python介绍 发展史 Python 2 or 3? 一. Python介绍 python的创始人为吉多·范罗苏姆(Guido van ...
- Codeforces 869C The Intriguing Obsession
题意:有三种颜色的岛屿各a,b,c座,你可以在上面建桥.联通的点必须满足以下条件:1.颜色不同.2.颜色相同且联通的两个点之间的最短路径为3 其实之用考虑两种颜色的即可,状态转移方程也不难推出:F[i ...
- Jarvis OJ - [XMAN]level3 - Writeup——ret2libc尝试
这次除了elf程序还附带一个动态链接库 先看一下,很一般的保护 思路分析 在ida中查看,可以确定通过read函数输入buf进行溢出,但是并没有看到合适的目标函数 但是用ida打开附带的链接库,可以看 ...
- javaweb学习总结(七)——HttpServletResponse对象(一)(转)
转载自 http://www.cnblogs.com/xdp-gacl/p/3789624.html Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对 ...
- WIN7下安装SVNserver端及client搭建协作环境
一.客户场景: 客户现场须要在虚拟机上封闭开发,所以须要搭建一个SVN协作开发环境.客户提供了一台全新的裸机安装的操作系统是WIN7旗舰版64位. 二.SVNserver搭建 1. SVNserver ...
- ajax初探--实现简单实时验证
学习技术最好的方式就是在做中学,做一个小demo来对前端输入进行实时验证. 利用ajax技术和Sevlet技术来实现,使用原生的js. 源码可访问,我的Github 什么是ajax Ajax 即&qu ...
- Git(二)Git几个区的关系与Git和GitHub的关联
前言 前面只是大概的介绍了一点基础的东西,接下来会更加深入的去了解一下Git. 一.Git的工作区.暂存区和版本库之间的区别和联系 1)工作区 在PC中能看得到的创建的一个管理仓库的目录.比如目录下G ...
- JAVA入门[2]-安装Maven
一.资料 1.官网: https://maven.apache.org/ 二.下载Maven 下载地址:https://maven.apache.org/download.cgi# 三.Windows ...
- inline-block解决
一.现象描述 真正意义上的inline-block水平呈现的元素间,换行显示或空格分隔的情况下会有间距 二.方法之移除空格 元素间留白间距出现的原因就是标签段之间的空格,因此,去掉HTML中的空格,自 ...