一、常用(普通)数组的构建

1.1 直接构建

let arr = ['mock1', 'mock2', 'mock3']

1.2 通过new Array

let arr = newArray('mock1', 'mock2', 'mock3')

let arr1 = newArray();
arr1[0] = 'mock1'
arr1[1] = 'mock2'
... //array可设定长度,但对于map并没什么用,后面详细介绍
let arr1 = new Array(9)

二、特殊数组的构建

2.1 构建相同内容的数组

直接构建法:

简单粗暴不推荐,如果数据多,不仅构建麻烦,而且不美观

let arr = ['mock', 'mock', 'mock']

循环法: for循环

比第一种要好,但是代码依然不美观

let arr = [];
for(var i = 0;i < 3;i++){
arr.push('mock')
}

fill: 使用一个固定值来填充数组

这种显然就方便又美观多了!

let newArr = new Array(3);
newArr.fill('mock')

2.1 构建顺序(倒序数组)

直接构建法:

数据多起来,10条、20条可要了亲命

let arr = ['mock1', 'mock2', 'mock3'...]

循环法: for循环

和2.1一样的道理

let arr = [];
for(var i = 0;i < 10;i++){
arr.push(`mock${i+1}`)
}

fill + map实现

这种显然就方便又美观多了!

let newArr = new Array(10).fill('').map( (item, index) => index+1);

console.log(newArr)

可以完美打印出[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

简单解释一下原理.

之所以要用fill结合map,因为new Array创建的空数组是无法map的.

比如new Array(3)创建的数组是[,,,],用map进行循环得不到任何结果.当然你说可以用for和length,我只是不太喜欢用for.map看起来更简洁舒服

所以我们新建了数组要向数组里真真切切填充一个(任何)数,因为到后面,其值还是会被map代替。

let arr = new Array(10).fill('任何数')

这时候就可以使用map方法了,然后通过每次return返回的值改变当前数组位置的值

arr.map( (item, index) => index+1 )

上面有几点要注意:

  1. map的时候,需要用的是序号值index,item(数组的值)对我们是没有意义的
  2. 当箭头函数的内容只有一行的时候,会自动return该行内容

总之,还是建议大家尽可能使用高质量、简洁的代码去构建项目.这样对性能也好,后面维护项目也好,都有很大的作用

JS快速构建数组方法的更多相关文章

  1. 转载: 我如何使用 Django + Vue.js 快速构建项目

    原文链接: https://www.ctolib.com/topics-109796.html 正文引用如下 引言 大U的技术课堂 的新年第一课,祝大家新的一年好好学习,天天向上:) 本篇将手把手教你 ...

  2. js中的数组方法

    数组的方法有数组原型方法,也有从object对象继承来的方法,这里我们只介绍数组的原型方法,数组原型方法主要有以下这些: join()push()和pop()shift() 和 unshift()so ...

  3. js中常用数组方法concat join push pop slice splice shift

    javascript给我们很多常用的 数组方法,极大方便了我们做程序.下面我们来介绍下常用的集中数组方法. 比如 concat() join() push() pop() unshift() shif ...

  4. js 快速生成数组的方法

    //实现方法一:循环赋值var arr1 = new Array(100);for(var i=0;i<arr1.length;i++){ arr1[i] = i;}console.log(ar ...

  5. js学习笔记——数组方法

    join() 把数组中所有元素转化为字符串并连接起来,并返回该字符串, var arr=[1,2,3]; var str=arr.join("#"); //str="1# ...

  6. 【笔记】JS中的数组方法

    push()方法:可以向数组的末尾添加一个或者多个元素,并且返回新的长度   pop()方法:可以删除数组最后一个元素,并且返回被删除的元素,注意:如果数组是空的,该方法不进行任何操作,返回undef ...

  7. js常用的数组方法

    1.创建数组的基本方法:  1.1 空数组  var obj=new Array();                 1.2 指定长度数组  var obj=new Array(size);     ...

  8. js快速去除数组重复项

    function unique1(arr) { var tmp = new Array(); tmp.push(arr[0]); for(var i=0;i<arr.length;i++) { ...

  9. 转载收藏(js数组方法大全)

    js数组方法大全 JavaScript中创建数组有两种方式 (一)使用 Array 构造函数: var arr1 = new Array(); //创建一个空数组var arr2 = new Arra ...

随机推荐

  1. 文本tfidf

    文本分类tf:词的频率 idf:逆文档频率 代码实例: # tf idf from sklearn.feature_extraction.text import TfidfVectorizer imp ...

  2. System.map文件的作用解析

    有关System.map文件的信息好象很缺乏.其实它一点也不神秘,并且在整个事情当中它并不象看上去那么得重要.但是由于缺乏必要的文档说明,使其显得比较神秘.它就象耳垂,我们每个人都有,但却不知道是干什 ...

  3. 解决Win 10上SSD缓慢问题

    标准硬盘驱动器(HDD)由于其高存储容量和低成本而长期以来一直是计算机的主要存储设备.固态硬盘(SSD)是另一种存储解决方案,正在逐步取代大多数硬盘驱动器.但是,随着时间的推移,SSD会因各种原因而大 ...

  4. 分享30道Redis面试题,面试官能问到的我都找到了

    1.什么是Redis?简述它的优缺点? Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到 ...

  5. zabbix 监控Nginx和PHP

    原理 Nginx和PHP(5.3及以上版本)都自带了一个状态页,默认没有开启,通过开启这个状态页即可获取实时的工作状态. Nginx状态获取 Nginx的配置默认是拒绝通过IP来访问,我们可以再默认虚 ...

  6. Web安全学习笔记之更新kali国内源

    vi /etc/apt/sources.list #中科大 deb http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contrib ...

  7. ELK学习笔记之Grok patterns正则匹配

    https://github.com/logstash-plugins/logstash-patterns-core/blob/master/patterns/grok-patterns USERNA ...

  8. HTTP小幺鸡接口管理工具安装与配置说明

    http://www.xiaoyaoji.cn/doc/TxybXPTdx 小幺鸡接口管理工具安装说明 使用可以参考:https://blog.csdn.net/qincidong/article/d ...

  9. Getting started with Kaggle -- Kaggle Competitions

    1: The Competition We'll be learning how to generate a submission for a Kaggle competition. Kaggle i ...

  10. 20155201 网络攻防技术 实验九 Web安全基础

    20155201 网络攻防技术 实验九 Web安全基础 一.实践内容 本实践的目标理解常用网络攻击技术的基本原理.Webgoat实践下相关实验. 二.报告内容: 1. 基础问题回答 1)SQL注入攻击 ...