arguments详解——函数内命名参数之映射
首先,arguments对象是所有(非箭头)函数中都可用的局部变量。你可以使用arguments对象在函数中引用函数的参数。此对象包含传递给函数的每个参数,第一个参数在索引0处。
arguments对象不是一个 Array 。它类似于Array,但除了length属性和索引元素之外没有任何Array属性。但是它可以被转换为一个真正的Array,
以下为四种方式:已验证
var args = Array.prototype.slice.call(arguments);
var args = [].slice.call(arguments); // ES2015
const args = Array.from(arguments);
const args = [...arguments];
1,非严格模式下,arguments与调用函数时传入的参数一一对应,不管是否有命名参数,
不存在命名参数时,参数只能通过arguments[i]调用;
存在命名参数时,参数可以通过arguments[i]或者参数名进行调用,映射关系,修改一个另一个也有变化(前提是命名参数与传入的参数数量相同,否则请看第二点)
无命名参数时:
console.log('---------------------使用arguments参数对所有函数执行操作------------------------');
//完全没有任何显式定义参数的函数
//迭代所有传入参数,然后通过索引标记获取每个元素的值
function sum() {
var sum = 0;
for (var i = 0; i < arguments.length; i++) {
sum += arguments[i];
}
return sum;
}
//调用函数并传入任意数量的参数
if (sum(1, 2) === 3) {
console.log("We can add two numbers.");
}
if (sum(1, 2, 3) === 6) {
console.log("We can add three numbers");
}
if (sum(1, 2, 3, 4) === 10) {
console.log('We can add four numbers.');
}

存在命名参数时:
console.log('-------------argument对象作为函数参数的别名----------------------');
//argument参数有一个有趣的特性:它可以作为函数参数的别名。例如,如果为arguments[0]赋一个新值,那么,同时也会改变第一个参数的值。
//检查person参数的值等于gardener,并作为第一个参数被传入。
function infiltrate(person) {
if (person === 'gardener') {
console.log("The person is a gardener.");
}
if (arguments[0] === 'gardener') {
console.log('The first argument is a gardener');
}
arguments[0] = 'ninja';
//改变argument对象的值也会改变相应的形参
if (person === 'ninja') {
console.log('The person is a ninja now.');
}
if (arguments[0] === 'ninja') {
console.log('The first argument is a ninja.');
}
person = 'gardener';
//这两种方式下,别名都正常工作了。
if (person === 'gardener') {
console.log('The person is a gardener once more.');
}
if (arguments[0] === 'gardener') {
console.log('The first argument is a gardener again.');
}
}
infiltrate("gardener");

2,非严格模式下arguments的length属性在调用函数完成后不可改变:
2.1通过arguments[i]添加新的属性也不客改变length属性
2.2通过arguments[i]添加的新属性可以通过arguments[i]访问到
2.3若传入参数少于定义参数那么在函数内部对定义参数赋值,新参数不可以通过arguments[i]访问到,且不客改变length属性(函数的定义参数是函数内部作用域的已定义变量,与在函数内部定义的变量没有不同)
综上所述,若传入参数不等于定义参数,那么多出的定义参数或者arguments则失去映射关系,如下所示:
function a(a,b,c){
arguments[2] = 10
console.log(arguments[2],c,arguments.length)
}
a(1,2,4)
a(5,6)

function a(a,b,c){
c = 10
console.log(arguments[2],c,arguments.length)
}
a(1,2,4)
a(5,6)

3,将arguments对象作为函数参数的别名使用时会影响代码的可读性,因此在JavaScript提供的严格模式中(strict mode)中将无法再使用它。arguments对象将不再作为参数的别名
<script type="text/javascript">
"use strict";
console.log('--------使用严格模式避免使用arguments别名---------------');
function infiltrate(person) {
if (person === 'gardener') {
console.log("The person is a gardener.");
} if (arguments[0] === 'gardener') {
console.log('The first argument is a gardener');
}
//改变第一个参数
arguments[0] = 'ninja';
//Person的参数值没有改变
if (person === 'ninja') {
console.log('The person is a ninja now.');
}
//第一个参数值被改变了
if (arguments[0] === 'ninja') {
console.log('The first argument is a ninja.');
}
}
infiltrate('gardener');
</script>

第一行代码use strict是一个简单的字符串,这将告诉JavaScript引擎,我们希望将下面的代码在严格模式下执行。严格模式将改变程序的执行结果,最终person参数的值和arguments参数的第一个中将不再相同。
//改变第一个参数
arguments[0] = 'ninja';
//Person的参数值没有改变
if (person === 'ninja') {
console.log('The person is a ninja now.');
}
//第一个参数值被改变了
if (arguments[0] === 'ninja') {
console.log('The first argument is a ninja.');
}
但与非严格模式不同的是,这一次arguments对象将不再作为参数的别名。如果想通过arguments[0]='ninja'改变第一个参数的值,这将不会改变person参数。
参考:javascript 理解函数调用-操作arguments参数 https://blog.csdn.net/zhangying1994/article/details/86529770
理解函数参数及arguments https://www.jianshu.com/p/75f8fa2ad073
JS中的arguments参数 https://blog.csdn.net/zjy_android_blog/article/details/80934042
Arguments 对象 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Functions/arguments
arguments详解——函数内命名参数之映射的更多相关文章
- JavaScript中的arguments详解
1. arguments arguments不是真正的数组,它是一个实参对象,每个实参对象都包含以数字为索引的一组元素以及length属性. (function () { console.log(ar ...
- JavaScript学习总结(三、函数声明和表达式、this、闭包和引用、arguments对象、函数间传递参数)
一.函数声明和表达式 函数声明: function test() {}; test(); //运行正常 function test() {}; 函数表达式: var test = functio ...
- Mysql常用show命令,show variables like xxx 详解,mysql运行时参数
MySQL中有很多的基本命令,show命令也是其中之一,在很多使用者中对show命令的使用还容易产生混淆,本文汇集了show命令的众多用法. 详细: http://dev.mysql.com/doc/ ...
- Python趣味入门9:函数是你走过的套路,详解函数、调用、参数及返回值
1.概念 琼恩·雪诺当上守夜人的司令后,为训练士兵对付僵尸兵团,把成功斩杀僵尸的一系列动作编排成了"葵花宝典剑法",这就是函数.相似,在计算机世界,一系列前后连续的计算机语句组合在 ...
- 【WebApi系列】详解WebApi如何传递参数
WebApi系列文章 [01]浅谈HTTP在WebApi开发中的运用 [02]聊聊WebApi体系结构 [03]详解WebApi参数的传递 [04]详解WebApi测试和PostMan [05]浅谈W ...
- 第4天:function对象(案例:获取当前日期属于当年第几天、arguments对象、函数类型、参数、返回值、自身调用)
获取当前日期输入当年第几天 //输入,年月日,获取这个日期是这一年的第几天 //年-月--日:20171月31日 function getDay(year,month,day){ //定义变量存储对应 ...
- js中arguments详解
在js中一切都是对象,连函数也是对象,函数名其实是引用函数定义对象的变量. 什么是arguments? 这个函数体内的arguments非常特殊,实际上是所在函数的一个内置类数组对象,可以用数组的[i ...
- 详解Linux内核红黑树算法的实现
转自:https://blog.csdn.net/npy_lp/article/details/7420689 内核源码:linux-2.6.38.8.tar.bz2 关于二叉查找树的概念请参考博文& ...
- arguments详解
arguments 是什么? 是一个对象,一个 很像数组的对象 arguments内容是什么? 1是函数运行时的实参列表 2收到实参收集起来,放到一个arguments对象里 在词法分析中,首先按形参 ...
随机推荐
- Anaconda折腾记(1)
Anaconda折腾记 谨此记录小白的我在Anaconda里面的摸爬滚打 更换更新源 可以不使用命令,直接进入C盘,进入user文件夹,进入当前的用户文件夹下,记得显示隐藏文件. 找到.condarc ...
- 第一次参赛经历:ecfinal总结
刚接到要去参加ec的消息时,还是非常激动的,毕竟第一次参赛就参加如此高水平的编程竞赛(更高水平的比赛就是wf). 教练临时组队,把三个从没在一起打过比赛的三个人组成一队,当时有点担心默契和配合上的问题 ...
- C++中的类型识别
1,为什么会提出类型识别概念呢? 1,为什么在 C 语言中没有提出这个概念呢,就是因为在 C++ 中引入了面向对象的特性,面向对象里面有一个非常重要的原则就是赋值兼容性原则: 2,在面向对象中可能出现 ...
- django 商城项目之购物车以及python中的一些redis命令
最近在用django restframe框架做一个商城项目,有一个关于购物车的业务逻辑,是用cookie和redis存储的购物车信息,在这里记录一下. 完成一个商城项目,如果不做一个购物车,就是十分可 ...
- [Vue] vue的一些面试题
1.v-model 的原理 v-model 是一个语法糖,它即可以支持原生表单元素,也可以支持自定义组件.v-model 在内部为不同的输入元素使用不同的属性并抛出不同的事件. text 和 text ...
- group by问题
在使用group by进行查询结果分组的时候,报错: 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contain ...
- 使用CXF开发WebService程序的总结(三):创建webservice客户端
1.创建一个maven子工程 ws_client,继承父工程 1.1 修改父工程pom配置 <modules> <module>ws_server</module> ...
- 机器学习聚类算法之DBSCAN
一.概念 DBSCAN是一种基于密度的聚类算法,DBSCAN需要两个参数,一个是以P为中心的邻域半径:另一个是以P为中心的邻域内的最低门限点的数量,即密度. 优点: 1.不需要提前设定分类簇数量,分类 ...
- Eureka实现高可用及为Eureka设置登录账号和密码
本文通过两个eureka相互注册实现注册中心的高可用,同时为注册中心配置认证登录. 需要用到的maven配置 <dependency> <groupId>org.springf ...
- C Make a Square Educational Codeforces Round 42 (Rated for Div. 2) (暴力枚举,字符串匹配)
C. Make a Square time limit per test2 seconds memory limit per test256 megabytes inputstandard input ...