JavaScript数组方法--concat、push
利用了两天的时间,使用typescript和原生js重构了一下JavaScript中数组对象的主要方法,可以移步github查看。
这里,按照MDN上的文档顺序,再重新学习一下数组方法吧。
- concat:
concat()
方法用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。
给出的示例是:var array1 = ['a', 'b', 'c'];
var array2 = ['d', 'e', 'f']; console.log(array1.concat(array2));期望输出:["a", "b", "c", "d", "e", "f"]。这也符合我们正常的使用方式。那么还有没有特殊的地方呢?
1、由于concat()方法返回一个新数组,那么如果不传参数,会怎样呢?var array1 = ['a', 'b', 'c'];
var arr3 = array1.concat()
console.log(array1==arr3); // false很明显,可以实现数组的浅拷贝。
2、如果参数不是数组呢?var array1 = ['a', 'b', 'c'];
var arr3 = array1.concat("3", true, null, undefined, {key: "value"})
console.log(arr3);输出结果:
把所有参数都当做数组元素拼接到array1后面,并返回一个新的数组实例。
想到了什么?这种情况是不是与push方法很像。区别在于push是修改原数组,concat是返回新数组。
到这里,我们是不是可以尝试重构一下concat的方法呢?function concat() {
if (!(arguments[0] instanceof Array)) throw new Error("请确保第一个参数类型为数组")
var results = []
for (var i = 0; i < arguments.length; i++) {
if (!(arguments[i] instanceof Array)) {
results[results.length] = arguments[i]
break;
}
for (var j = 0; j < arguments[i].length; j++) {
results[results.length] = arguments[i][j]
}
}
return results
}稍作解释的是,没有在数组原型上重构各种方法,仅仅是封装为一个个的函数,所以函数的第一个参数,都要求是需要操作的数组。
push:
push()
方法将一个或多个元素添加到数组的末尾,并返回该数组的新长度。
按照顺序而言,这里不应该是push的,但是既然在谈concat的时候,提到push了,那么就先来push吧!
惯例,先看MDN给出的示例:var animals = ['pigs', 'goats', 'sheep']; console.log(animals.push('cows'));
// expected output: 4 console.log(animals);
// expected output: Array ["pigs", "goats", "sheep", "cows"] animals.push('chickens'); console.log(animals);
// expected output: Array ["pigs", "goats", "sheep", "cows", "chickens"]看结果:
很容易理解,push修改的是原数组,并返回修改后的数组长度。
同理,我们分别测试:
1、不传参数var animals = ['pigs', 'goats', 'sheep'];
var b = animals.push()
console.log(b );输出值为3,那么3是哪里来的呢?很明显就是animals.length,突然美滋滋的,下次再获取数组长度,是不是可以装X一下!!!
2、传递多个不同类型的参数var animals = [];
animals.push(['dogs', []],"3", true, null, undefined, {key: "value"})
console.log(animals);查看结果:
就是说不管什么类型的参数,一个参数都将作为一个元素,插入到原数组当中。
那就重构一下push吧!第一个参数也是需要操作的数组!function push(arr) {
if (!(arr instanceof Array)) throw new Error("请确保参数类型为数组")
for (var i = 1; i < arguments.length; i++) {
arr[arr.length] = arguments[i]
}
return arr.length
}
剩余的方法,期待后续了!
JavaScript数组方法--concat、push的更多相关文章
- JavaScript数组方法--every、some、fill
接上一篇,JavaScript数组方法--concat.push,继续其他的数组方法. every:every() 方法测试数组的所有元素是否都通过了指定函数的测试. 先看其使用方法: functio ...
- 【译】你应该了解的JavaScript数组方法
让我们来做一个大胆的声明:for循环通常是无用的,而且还导致代码难以理解.当涉及迭代数组.查找元素.或对其排序或者你想到的任何东西,都可能有一个你可以使用的数组方法. 然而,尽管这些方法很有用,但是其 ...
- JavaScript数组方法大全(推荐)
原网址:http://www.jb51.net/article/87930.htm 数组在笔试中经常会出现的面试题,javascript中的数组与其他语言中的数组有些不同,为了方便之后数组的方法学习, ...
- JavaScript数组方法详解
JavaScript数组方法详解 JavaScript中数组的方法种类众多,在ES3-ES7不同版本时期都有新方法:并且数组的方法还有原型方法和从object继承的方法,这里我们只介绍数组在每个版本中 ...
- JavaScript数组方法大集合
JavaScript数组方法集合 本文总结一下js数组处理用到的所有的方法.自己做个笔记. 数组方法 concat() 合并两个或多个数组 concat()能合并两个或者多个数组,不会更改当前数组,而 ...
- 一站式超全JavaScript数组方法大全
一站式JavaScript数组方法大全(建议收藏) 方法一览表 详细操作 本人总结了JavaScript中有关数组的几乎所有方法(包含ES6之后新增的),并逐一用代码进行演示使用,希望可以帮助大家! ...
- 2018.2.27 JavaScript数组方法应用
JavaScript数组方法应用 1.找出元素item在给定数组arr中的位置 function indexOf(arr,item){ return arr.indexOf(item); } func ...
- JavaScript 数组方法处理字符串 prototype
js中数组有许多方法,如join.map,reverse.字符串没有这些方法,可以“借用”数组的方法来处理字符串. <!doctype html> <html lang=" ...
- JavaScript数组方法速查,32个数组的常用方法和属性
JavaScript数组方法速查手册极简版 http://30ke.cn/doc/js-array-method JavaScript数组方法速查手册极简版中共收了32个数组的常用方法和属性,并根据方 ...
随机推荐
- 03MYSQL数据库
mySQL 数据库 储存数据,属于中小型数据库 默认端口号 3306 密码root sql是一门编程语言 结构化查询语言 是强类型语言(定义变量时要指定变量类型) 字符串有两种类型: 定长: ...
- 搭建开发环境3) Debian8 安装Netbeans
1.下载最新版的Netbeans.sh(netbeans-8.2-linux.sh) 2.进入管理员账户,移动到下载的目录 ./netbeans-8.2-linux.sh //执行安装脚本 出现界面安 ...
- 云服务器 ECS > 建站教程 > 部署 LAMP (CentOS 7.2 ,Apache版本:2.4.23, Mysql 版本:5.7.17 , Php版本:7.0.12)
云服务器 ECS > 建站教程 > 部署 LAMP (CentOS 7.2) 部署 LAMP (CentOS 7.2) 文档提供方:上海驻云信息科技有限公司 更新时间:2017-06 ...
- [工作积累] shadow map问题汇总
1.基本问题和相关 Common Techniques to Improve Shadow Depth Maps: https://msdn.microsoft.com/en-us/library/w ...
- SpeedReader for Mac(快速阅读器)v1.6免费版
SpeedReader for Mac是一款运行在Mac平台上的阅读软件,通过这款软件就可以自行调整阅读速度.通过SpeedReader Mac版用户可以将想要阅读的内容拖入到软件中,调整速度和字体, ...
- edgedb 集成timescaledb
timescaledb 是一个强大的pg 扩展,可以让我们的pg 数据库支持时序数据库的能力,以下测试下与edgedb 集成 预备 因为edgedb 当前是基于pg11 开发的,所以需要使用pg11 ...
- Technical
CAN FD (CAN with Flexible Data-Rate) is an extension to the original CAN bus protocol specified in I ...
- python如何输出文件的年月日
import time print('{}BiasedMF312and4414_rt.txt'.format(time.strftime("%Y-%m-%d"))) 输出: 201 ...
- HBASE基础知识总结
HBASE基础知识总结 一,概要说明 文章首先回顾HBase 的数据模型和数据层级结构,对数据的每个层级的作用和架构进行了详细阐述:随后介绍了数据写入和读取的详细流程.先把架构图和流程图来坐镇. 架构 ...
- HTTPD三种工作模型
HTTPD三种工作模型 MPM是apache的多道处理模块,用于定义apache对客户端请求的处理方式.在linux中apache常用的三种MPM模型分别是prefork.worker和event. ...