JS快速构建数组方法
一、常用(普通)数组的构建
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 )
上面有几点要注意:
- map的时候,需要用的是序号值index,item(数组的值)对我们是没有意义的
- 当箭头函数的内容只有一行的时候,会自动return该行内容
总之,还是建议大家尽可能使用高质量、简洁的代码去构建项目.这样对性能也好,后面维护项目也好,都有很大的作用
JS快速构建数组方法的更多相关文章
- 转载: 我如何使用 Django + Vue.js 快速构建项目
原文链接: https://www.ctolib.com/topics-109796.html 正文引用如下 引言 大U的技术课堂 的新年第一课,祝大家新的一年好好学习,天天向上:) 本篇将手把手教你 ...
- js中的数组方法
数组的方法有数组原型方法,也有从object对象继承来的方法,这里我们只介绍数组的原型方法,数组原型方法主要有以下这些: join()push()和pop()shift() 和 unshift()so ...
- js中常用数组方法concat join push pop slice splice shift
javascript给我们很多常用的 数组方法,极大方便了我们做程序.下面我们来介绍下常用的集中数组方法. 比如 concat() join() push() pop() unshift() shif ...
- js 快速生成数组的方法
//实现方法一:循环赋值var arr1 = new Array(100);for(var i=0;i<arr1.length;i++){ arr1[i] = i;}console.log(ar ...
- js学习笔记——数组方法
join() 把数组中所有元素转化为字符串并连接起来,并返回该字符串, var arr=[1,2,3]; var str=arr.join("#"); //str="1# ...
- 【笔记】JS中的数组方法
push()方法:可以向数组的末尾添加一个或者多个元素,并且返回新的长度 pop()方法:可以删除数组最后一个元素,并且返回被删除的元素,注意:如果数组是空的,该方法不进行任何操作,返回undef ...
- js常用的数组方法
1.创建数组的基本方法: 1.1 空数组 var obj=new Array(); 1.2 指定长度数组 var obj=new Array(size); ...
- js快速去除数组重复项
function unique1(arr) { var tmp = new Array(); tmp.push(arr[0]); for(var i=0;i<arr.length;i++) { ...
- 转载收藏(js数组方法大全)
js数组方法大全 JavaScript中创建数组有两种方式 (一)使用 Array 构造函数: var arr1 = new Array(); //创建一个空数组var arr2 = new Arra ...
随机推荐
- 大数据自学2-Hue集成环境中使用Sqoop组件从Sql Server导数据到Hive/HDFS
安装完CDH后,发现里面的东东实在是太多了,对于一个初学大数据的来说就犹如刘姥姥进了大观园,很新奇,这些东东每个单拿出来都够喝一壶的. 接来来就是一步一步地学习了,先大致学习了每个模组大致做什么用的, ...
- sql语句查询排序
一:sql语句单词意义 order by 是用在where条件之后,用来对查询结果进行排序 order by 字段名 asc/desc asc 表示升序(默认为asc,可以省略) desc表示降序 o ...
- Java五大框架
2017-6-13 Lifusen 此文章仅代表个人观点,如有问题提出请联系Q:570429601 1.Hibernate (开放源代码的对象关系映射框架) Hibernate是一个开放源代码的对象关 ...
- Web开发相关笔记 #04# WebSocket
本文的主要内容: HTTP VS. WebSocket WebSocket 的客户端实现(JavaScript) WebSocket 的服务端实现(Java & apache WebSocke ...
- linux下nginx整合php
在nginx中药使用php可不像apache那样,因为apache是把php当做自己的一个模块来启动的, 而我们的nginx是把http请求转发给php程序,也就是说,php和nginx是相互独立的的 ...
- Linux普通用户使用sudo免输密码(Debian/Redhat通用)
今天使用的Debian,由于使用的是普通用户,而使用的sudo都需要输入密码的繁琐操作, 下面是使用sudo时免输入密码. 需要管理员权限进行以下操作. 修改sudoers vim /etc/sudo ...
- log4j2使用介绍
工作中,用到了log4j2,以前只接触过log4j,也没有太过深入,这次就稍微系统的学习了以下log4j2. 一.引入pom.xml 使用maven作为项目的构建环境,pom.xml使用slf4j,s ...
- mysql 的delete from 和update子查询限制
最经做项目时发现的问题,好像在update时也有... 网上查到的资料如下: 1.使用mysql进行delete from操作时,若子查询的 FROM 字句和更新/删除对象使用同一张表,会出现错误. ...
- Python3基础 list index 全列表查找与指定索引范围查找
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- java 动态代理总结
首先:定义一个接口// 只能是一个接口 例: package DongTai; public interface dongtai { public void show(); } 接着:定义一个被代理类 ...