Array.form

把不是数组的东西变成数组。最常见的就是把伪数组变成数组

那么什么是伪数组
这就是伪数组,因为它不是继承自Array的原型的对象。它只是一个看起来很像数组的数组

只看下面的代码。a看起来很像数组,但是它又不是一个数组 生成的。所以它就是一个伪数组

伪数组就是拥有数组的下标和length。但是没有数据的任何api

例如我要在数组内添加一个新的内容 就会报错。

es5的方法,把伪数组变成数组

为什么要用Array.prototype.slice.call呢 ,因为js忘了给出Array方法方便的把伪数组转换成数组。所以只能用这个。

slice相当于下面的代码。创建一个真正的数组,循环伪数组,复制伪数组的每一项到真数组内。然后返回这个真数组。

es6用Array.from

api

把字符串变成数组,把Set变成数组。

下面选中的是一个伪数组。像数组的都有length

相当于前面没有定义 0到4这5项,直接给了个length为5

从一个没有任何下标的伪数组里,搞出一个长度为5的数组

每一项都是undefined,但是length是5

创建一个长度为n的数组,这是一个经典的面试题。如果不用Array.form应该怎么做?

使用new Array(5)这种方式,数组有bug。它没有任何的下标。
new Array(5)得到的是没有下标的数组。没有下标你就没法去map

用map循环每一项并加1返回,但是结果还是一个空的,相当于是没有做任何的操作。Map不会遍历不存在的下标。

如果用Array.form的形式


es5的方式创建有下标的长度为5的数组。

api内数组去重的方法。concat是链接两个数组,

let arr = [].concat.apply([], arguments);最前面是一个空的数组,连接一个arguments组成的数组, 最终返回的应该是一个arguments组成的数组副本

js中Array.apply(null,Array(3))与Array(3)的区别是什么?参考简书的地址: https://www.jianshu.com/p/6c7d0b18d4ca

请创建长度为n,但是每一项都是指定项的数组

用一个函数创建6个6

ES6的方式

ES5的方式

首先是创建一个有7个位置的数组,7个中间有6个空隙 所以会得到 6个6 

原理就是用空隙的东西来做。有点取巧

ES6简写的方式,一句话

Array.of

把你写的参数变成数组

得到了由你传的参数组成的数组

那么我为什么不直接这么写呢???

无聊的API

Array.prototype.Fill

prototype是原型,所以可以直接在数组的对象上使用fill方法

把传的值全部填充到数组。

所以上面的面试题,可以直接用fill填充就可以了。

从第一个开始填充3一直到数组的末尾,也就是从1开始把1改成了3,后面所有的都改成3

find

find必须接受一个函数。

查找某一项name等于a2的


也可以for循环来查找

find只找到一个,filter找到两个

findIndex

找对象的索引

copyWithin


在0的位置上放3和4之间的东西。就是把 1换成了4

把0的位置的换成,2个位置的值,从2开始到3结束。也就是把0的位置的a换成了c

entries

keys

也是得到的一个key的可迭代对象。
‘’

values

结束

ES6深入浅出-11 ES6新增的API(上)-2.Array新增API的更多相关文章

  1. ES6深入浅出-11 ES6新增的API(上)-1.Object.assign

    这些都是es6才有的 Object.assign 在a加上三个属性 分别是p1\p2\p3 以前是这么去加 b的三个属性p1.p2.p3就全部复制到a这个对象上了. 把后面的东西放到前面的东西上 两个 ...

  2. Core Web API上使用Swagger提供API文档

    在ASP.NET Core Web API上使用Swagger提供API文档   我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的AP ...

  3. ES6深入浅出-12 ES6新增的API(下)-1.录屏

    String.includes es5里面判断字符串是否存在的方法 search searcg的厉害之处是可以使用正则 match正则的方式 repeat -1遍,就不合法 startsWith 判断 ...

  4. 在ASP.NET Core Web API上使用Swagger提供API文档

    我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...

  5. ES6深入浅出-10 ES6新增的数据类型-2.Set与数组去重

    一种新的数据类型,它是对象的一种,Set,很像数组,又不是数组. Set 类型 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Refe ...

  6. ES6深入浅出-10 ES6新增的数据类型-1.Symbol与隐藏属性

    ES5现有的数据类型.7种数据类型. 新的类型是属于Object 最普通的类型.plain object 数组array 函数function 下面这些都属于Object类型. 今天要讲的 set类型 ...

  7. ES6深入浅出-7 新版的类(上集)-1.介绍原型

    ES6新出的关键class BE受雇与网景开发了JS 当我们在写一个对象的时候,我们实际上内存的形式表示. obj等于一个空对象,可以直接toString.它为什么可以有toString window ...

  8. ES6深入浅出-7 新版的类(上集)-2.介绍JS中的类

    声明对象原型,公有属性. obj对象,它用一个属性__proto__记录了自己的原型 改掉它的原型为公有属性.那么obj这个对象及有了hi的方法.因为obj自己没有hi.那么就去自己的原型上去找了. ...

  9. ES6深入浅出-10 ES6新增的数据类型-3.其他类型

    Map类型 Map 类型 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Map Ma ...

随机推荐

  1. Django --- csrf相关,auth相关

    目录 1.csrf相关 1.跨站请求伪造 2.跨站请求伪造问题解决 3.crsf中间件 4.csrf装饰FBV的装饰器 5.csrf装饰CBV的装饰器 6.django settings源码刨析 2. ...

  2. shellshock溢出攻击

    实验背景 2014年9月24日,Bash中发现了一个严重漏洞shellshock,该漏洞可用于许多系统,并且既可以远程也可以在本地触发.在本实验中,需要亲手重现攻击来理解该漏洞,并回答一些问题. 什么 ...

  3. 07 Node.js安装及环境配置

    二.安装Node.js步骤 1.下载对应你系统的Node.js版本:https://nodejs.org/en/download/2.选安装目录进行安装3.环境配置4.测试 开始安装 1.下载完成后, ...

  4. jupyter安装小结

    jupyter安装小结 更新时间:2016年03月13日 15:42:37   投稿:hebedich    我要评论 jupyter (之前的 ipython notebook )于我的最大意义在于 ...

  5. Kubernetes 学习5 kubernetes资源清单定义入门

    一.kubernetes是有一个restful风格的 API,把各种操作对象都一律当做资源来管理.并且可通过标准的HTTP请求的方法 GET,PUT,DELETE,POST,等方法来完成操作,不过是通 ...

  6. 数据库访问优化之四:减少数据库服务器CPU运算

    1.使用绑定变量 绑定变量是指SQL中对变化的值采用变量参数的形式提交,而不是在SQL中直接拼写对应的值. 非绑定变量写法:Select * from employee where id=123456 ...

  7. Kibana 的安装(Windows版本)

    一.安装 安装条件 保证安装了JDK 保证安装node 保证安装了Elasticsearch 1.点击kibana官网下载  [kibana的版本和elasticsearch的版本和必须一致] 2.修 ...

  8. 12、基于yarn的提交模式

    一.三种提交模式 1.Spark内核架构,其实就是第一种模式,standalone模式,基于Spark自己的Master-Worker集群. 2.第二种,是基于YARN的yarn-cluster模式. ...

  9. (26)打鸡儿教你Vue.js

    weex框架的使用 1.weex开发入门 2.weex开发环境搭建 3.掌握部分weex组件模块 4.了解一些vue基本常见语法 5.制作一个接近原生应用体验的app weex介绍 安装开发环境 We ...

  10. Mybatis 通用Mapper增强

    1.确保是个Maven项目,确保Spring与Mybatis正确配置. 2.新建一个自定义通用Mapper. /** * BaseMapper接口:使mapper包含完整的CRUD方法<br&g ...