JS---arguments对象

1. 什么是 arguments

百度说:arguments 是一个类数组对象代表传给一个function的参数列表。(读不懂,看下面代码)

先看一段代码:

function printArgs() {console.log(arguments);}printArgs("A", "a", 0, { foo: "Hello, arguments" });

执行结果是:

["A", "a", 0, Object]

控制台打印出来的是一个数组,但并不是真正的数组,所以说arguments 是一个类数组的对象,我叫他伪数组

测试在函数内部打印 console.log(arguments[2]);    //0

2. arguments 操作

2.1 arguments length

arguments 是个类数组对象,其包含一个 length 属性,可以用 arguments.length 来获得传入函数的参数个数。

function func() {

console.log("The number of parameters is " + arguments.length);

}

func();

func(1, 2);

func(1, 2, 3);

执行结果如下:

The number of parameters is 0

The number of parameters is 2

The number of parameters is 3

2.2 arguments 转数组

通常使用下面的方法来将 arguments 转换成数组:

Array.prototype.slice.call(arguments);

还有一个更简短的写法:

[ ].slice.call(arguments);

在这里,只是简单地调用了空数组的 slice 方法,而没有从 Array 的原型层面调用。

问:为什么上面两种方法可以转换呢?

首先,slice 方法得到的结果是一个数组,参数便是 arguments。事实上,满足一定条件的对象都能被 slice 方法转换成数组。看个例子:

const obj = { 0: "A", 1: "B", length: 2 };

const result = [].slice.call(obj);

console.log(Array.isArray(result), result);   //true ["A", "B"]

从上面例子可以看出,条件就是:

1) 属性为 0,1,2…;

2) 具有 length 属性;

2.3 修改 arguments 值

在严格模式与非严格模式下,修改函数参数值表现的结果不一样。

function foo(a) {

"use strict";

console.log(a, arguments[0]);

a = 10;

console.log(a, arguments[0]);

arguments[0] = 20;

console.log(a, arguments[0]);

}

foo(1);

输出:

1 1

10 1

10 20

另一个非严格模式的例子:

function foo(a) {

console.log(a, arguments[0]);

a = 10;

console.log(a, arguments[0]);

arguments[0] = 20;

console.log(a, arguments[0]);

}

foo(1);

输出结果为:

1 1

10 10

20 20

从上面的两个例子中可以看出,在严格模式下,函数中的参数与 arguments 对象没有联系,修改一个值不会改变另一个值。而在非严格模式下,两个会互相影响。

2.4 将参数从一个函数传递到另一个函数

下面是将参数从一个函数传递到另一个函数的推荐做法。

function foo() {

bar.apply(this, arguments);

}function bar(a, b, c) {

// logic

}

2.5 arguments 与重载

很多语言中都有重载,但 JavaScript 中没有。先看个例子:

function add(num1, num2) {

console.log("Method one");

return num1 + num2;

}

function add(num1, num2, num3) {

console.log("Method two");

return num1 + num2 + num3;

}

add(1, 2);

add(1, 2, 3);

执行结果为:

Method two

Method two

所以,JavaScript 中,函数并没有根据参数的不同而产生不同的调用。

是不是 JavaScript 中就没有重载了呢?并不是,我们可以利用 arguments 模拟重载。还是上面的例子。

function add(num1, num2, num3) {

if (arguments.length === 2) {

console.log("Result is " + (num1 + num2));

}

else if (arguments.length === 3) {

console.log("Result is " + (num1 + num2 + num3));

}

}

add(1, 2);

add(1, 2, 3)

执行结果如下:

Result is 3Result is 6

3. ES6 中的 arguments

3.1 扩展操作符

function func() {

console.log(...arguments);

}

func(1, 2, 3);

执行结果是:

1 2 3

简洁地讲,扩展操作符可以将 arguments 展开成独立的参数。

3.2 Rest 参数

function func(firstArg, ...restArgs) {

console.log(Array.isArray(restArgs));

console.log(firstArg, restArgs);

}

func(1, 2, 3);

执行结果是:

true1 [2, 3]

从上面的结果可以看出,Rest 参数表示除了明确指定剩下的参数集合,类型是 Array。

3.3 默认参数

栗子:

function func(firstArg = 0, secondArg = 1) {

console.log(arguments[0], arguments[1]);

console.log(firstArg, secondArg);

}

func(99);

执行结果是:

99 undefined99 1

可见,默认参数对 arguments 没有影响,arguments 还是仅仅表示调用函数时所传入的所有参数。

3.4 arguments 转数组

Array.from() 是个非常推荐的方法,其可以将所有类数组对象转换成数组。

4. 数组与类数组对象

数组具有一个基本特征:索引。这是一般对象所没有的。

const obj = { 0: "a", 1: "b" };const arr = [ "a", "b" ];

我们利用 obj[0]、arr[0] 都能取得自己想要的数据,但取得数据的方式确实不同的。obj[0] 是利用对象的键值对存取数据,而arr[0] 却是利用数组的索引。事实上,Object 与 Array 的唯一区别就是 Object 的属性是 string,而 Array 的索引是 number。

下面看看类数组对象。

伪数组的特性就是长得像数组,包含一组数据以及拥有一个 length 属性,但是没有任何 Array 的方法。再具体的说,length 属性是个非负整数,上限是 JavaScript 中能精确表达的最大数字;另外,类数组对象的 length 值无法自动改变。

如何自己创建一个类数组对象?

function Foo() {}

Foo.prototype = Object.create(Array.prototype);

const foo = new Foo();

foo.push('A');console.log(foo, foo.length);console.log("foo is an array? " + Array.isArray(foo));

执行结果是:

["A"] 1

foo is an array? false

也就是说 Foo 的示例拥有 Array 的所有方法,但类型不是 Array。

如果不需要 Array 的所有方法,只需要部分怎么办呢?

function Bar() {}

Bar.prototype.push = Array.prototype.push;

const bar = new Bar();

bar.push('A');

bar.push('B');console.log(bar);

执行结果是:

Bar {0: "A", 1: "B", length: 2}

JS高级---argument详解(一看机会)相关推荐

  1. php和js调试,JS调试使用详解

    这次给大家带来JS调试使用详解,JS调试的注意事项有哪些,下面就是实战案例,一起来看一下. 试想一下:出现了某个bug,有人用几分钟就搞定了,有人用了半天或者一天都找不到原因所在.你愿意当前者还是后者 ...

  2. Python中的高级数据结构详解

    这篇文章主要介绍了Python中的高级数据结构详解,本文讲解了Collection.Array.Heapq.Bisect.Weakref.Copy以及Pprint这些数据结构的用法,需要的朋友可以参考 ...

  3. js_long.php,protobuf.js 与 Long.js的使用详解

    这次给大家带来protobuf.js 与 Long.js的使用详解,是急用protobuf.js 与 Long.js的注意事项有哪些,下面就是实战案例,一起来看一下. protobuf.js的结构和w ...

  4. Python中第三方库Requests库的高级用法详解

    Python中第三方库Requests库的高级用法详解 虽然Python的标准库中urllib2模块已经包含了平常我们使用的大多数功能,但是它的API使用起来让人实在感觉不好.它已经不适合现在的时代, ...

  5. js排序算法详解-归并排序

    js系列教程5-数据结构和算法全解 js排序算法详解-归并排序 归并排序其实可以类比二分法,二分法其实就是二等分的意思,简而言之就是不断和新序列的中间值进行比较.归并排序似乎有异曲同工之妙,什么意思呢 ...

  6. js排序算法详解-计数排序

    全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-计数排序 计数排序就是遍历数组记录数组下的元素出现过多次,然后把这个元素找个位置先安置下来,简单点说就是以原数 ...

  7. js排序算法详解-堆排序

    全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-堆排序 这种排序方式呢,理论性太强,看动图的时候满脸写着懵逼,多看几遍似乎明白了编者的意图,但是要把这种理论的 ...

  8. js排序算法详解-快速排序

    全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-快速排序 既然是快速排序,那顾名思义一定很快,快的连小编都被懵逼了好几圈!建议先不要看动图,先看第一种写法: ...

  9. js排序算法详解-希尔排序

    全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-希尔排序 希尔排序,直接上图: 像这个算法看图理解起来并不是很难,就像比赛一样,1-6一组,2-7一组,每差5 ...

最新文章

  1. TabelView嵌套CollectionView高度适应
  2. JS给html控件赋值
  3. C语言编写2048小游戏
  4. 如何在Windows中快速轻松地将文件发送到SkyDrive
  5. [CentOS] 打造vim环境
  6. python最简分数_1062 最简分数 Python实现
  7. 部分xcode插件可能有新版本
  8. 都说人工智能入门难?但80%的人都错了……
  9. Java获取接口所有实现类的方式
  10. PCL之估计整个点云表面法向量
  11. 学计算机专科好还是牙医好,孩子明年高考,牙科、计算机两个专业,怎么选?...
  12. AEJoy ——表达式代码列表和示例(四)【代码详解】
  13. 白杨SEO:聊聊微信红包封面、微信8.0状态背景图片和视频素材背后的商机
  14. 鸿蒙系统不可能有了,【图片】华为鸿蒙系统的厉害之处在于 你可能非用不可 !【手机吧】_百度贴吧...
  15. 中兴ZTE:五年工作感想
  16. IoT全品类全场景来了,但5G时代“大雁群飞”仍需紧盯“服务”
  17. 用canvas画圆形雷达图
  18. Android 双卡双待识别
  19. 简单美化 Win 10 的 CMD 命令行终端界面
  20. 论文研读——n个物体相互间的碰撞避免

热门文章

  1. tkinter 开发的 算卦小软件|python
  2. Ethereum 介绍
  3. 人工智能开讲:综述:目标检测二十年
  4. IDEA--如何解决Java程序包xxxx不存在
  5. 以太网联盟:400GbE后,更高速率以太网接口如何选择,800GbE, 1 TbE 还是 1.6TbE ?
  6. jquery简单问答游戏
  7. windows服务器通过nginx配置https
  8. 如何配置HTTPS服务器
  9. java导入csv分隔符_基于Java的CSV格式文件处理(excel逗号分隔符文件) | 学步园...
  10. windows如何打开Telnet命令