Arguments(Array-Like Objects)

  arguments对象是所有(非箭头)函数中都可用的局部变量

  拥有四个属性(按照规范来说只有三个了----caller)

  •   arguments.callee---指向当前执行的函数
  •   agruments.caller----指向调用当前函数的函数 (已移除)
  •   arguments.length---指向传递给当前函数的参数数量
  •   arguments.arguments--- 返回一个新的Array迭代器对象,该对象包含参数中每个索引的值

arguments对象可以与剩余参数默认参数解构赋值参数结合使用

function func(...args){
return args
} func(1,2,3) // [1,2,3] /* --------------------------------------------------------- */ function func(a) {
arguments[0] = 99; // 更新了arguments[0] 同样更新了a
console.log(a);
}
func(10); // "use strict"
func(10); // /* --------------------------------------------------------- */ function func(a) {
a = 99; // 更新了a 同样更新了arguments[0]
console.log(arguments[0]);
}
func(10); // "use strict"
func(10); // /* --------------------------------------------------------- */ function func(a = 55) {
arguments[0] = 99; // 更新了arguments[0]不会更新a
console.log(a);
}
func(10); // /* --------------------------------------------------------- */ function func(a = 55) {
a = 99; // 更新了a不会更新arguments[0]
console.log(arguments[0]);
}
func(10); // 总结:
不在严格模式下,arguments[0]改变,会使相对应的形参也发生改变,
修改形参,arguments[0]也会相应被修改
而在严格模式则不会被修改

数组

拥有三个属性,3个方法,N个实例方法(原谅我不数了)

数组是一种类列表对象,它的原型中提供了遍历和修改元素的相关操作

数组与Arguments的区别

  数组是构造函数 typeof Array ( function)

  Arguments是所有(非箭头)函数中都可用的局部变量   使用方式只能在函数中

将Arguments转为Array的方法(摘自hanzichi老师

function fn() {
// Uncaught TypeError: arguments.push is not a function
// arguments.push(4); var arr = [];
for (var i = 0, len = arguments.length; i < len; i++)
arr[i] = arguments[i]; arr.push(4); // [1, 2, 3, 4]
} fn(1, 2, 3); /* ------------------------------------------ */ function fn() {
var arr = Array.prototype.slice.call(arguments);
arr.push(4); // arr -> [1, 2, 3, 4]
} fn(1, 2, 3);
或者可以用 [] 代替 Array.prototype 节省几个字节。 function fn() {
var arr = [].slice.call(arguments);
arr.push(4); // arr -> [1, 2, 3, 4]
} fn(1, 2, 3); /* ------------------------------------------ */
// es6语法
var str = "helloworld";
var arr = Array.from(str);
// ["h", "e", "l", "l", "o", "w", "o", "r", "l", "d"] /* ------------------------------------------ */
// 兼容ie方法 function nodeListToArray(nodes){
var arr, length; try {
// works in every browser except IE
arr = [].slice.call(nodes);
return arr;
} catch(err){
// slower, but works in IE
arr = [];
length = nodes.length; for(var i = 0; i < length; i++){
arr.push(nodes[i]);
} return arr;
}
}

资料参考:MDN Arguments   MDN Array  hanzichi老师的见解

数组和arguments的更多相关文章

  1. 伪数组(arguments及字符串)转数组的方法 贼简单

    超简单的伪数组转数组的方法, 简单到令人发指! (这里伪数组使用arguments) 1.使用 Array.prototype.slice Array.prototype.slice.call(arg ...

  2. 08-为数组和arguments

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  3. (三十六)类数组对象arguments

    类数组对象:arguments 在函数调用时,我们总能见到arguments这个对象,它具体是用来干什么的呢?感觉逼格非常高呢 函数在使用时,我们总会位函数传入各种参数,arguments会将参数储存 ...

  4. 类数组对象arguments 和 数组对象

    arguments并不是一个真正的数组,而是一个“类似数组(array-like)”的对象: 就像下面的这段输出,就是典型的类数组对象: {0:12, 1:23} 一.类数组 VS 数组 相同点: 都 ...

  5. 浅谈js的类数组对象arguments

    类数组对象:arguments总所周知,js是一门相当灵活的语言.当我们在js中在调用一个函数的时候,我们经常会给这个函数传递一些参数,js把传入到这个函数的全部参数存储在一个叫做arguments的 ...

  6. js 类数组对象arguments

    function Add() { for (var i = 0; i < arguments.length; i++) { console.log(arguments[i]); } } Add( ...

  7. 将arguments转换成数组的方法

    将函数里的arguments,转换成一个真正的数组的方法,arguments是个类数组,除了有实参所组成的类似数组以外,还有自己的属性,如callee,arguments.callee就是当前正在执行 ...

  8. one:arguments对象伪数组

    这是我的第一个博客 <script> //计算N个数字的和 //定义一个函数,如果不确定用户是否传入了参数,或者说不知道用户传入了几个参数,没办法计算, // 但是如果在函数中知道了参数的 ...

  9. javascript arguments(转)

    什么是arguments arguments 是是JavaScript里的一个内置对象,它很古怪,也经常被人所忽视,但实际上是很重要的.所有主要的js函数库都利用了arguments对象.所以agru ...

随机推荐

  1. crontab定期执行shell脚本

    [场景]: 需要定期运行Hadoop的MapReduce [解决办法]: 编写一个运行MapReduce的Shell脚本.然后使用crontab配置定时任务. [Shell脚本] #!/usr/bin ...

  2. 4.3.3 thread对性能有何帮助

    public class ThreadLocalDemo { public static final int GE_COUNT = 10000000; public static final int ...

  3. centos7用fdisk进行分区

    1.查看分区信息:fdisk -l 从上面可以看到,/dev/sdb分区还没有使用,现在将其划分成2个10G的分区. 2.执行:fdisk /dev/sdb 1):fdisk命令参数 p:打印分区表. ...

  4. 策略和计费控制(PCC)系统研究

    策略和计费控制(PCC)系统研究 研究内容 [TOC "float:left"] 策略与计费控制(PCC)框架1 [架构图](achitecture.png "Archi ...

  5. Servlet 学习总结-1

    JavaWeb应用程序中所有的请求-响应都是由Servlet来完成的.Servlet是Java Web的核心程序,所有的网址(请求-响应)都交给Servlet来处理. Servlet在Web应用中被映 ...

  6. IT技术公众号推荐

    获取二维码方法:http://open.weixin.qq.com/qr/code/?username=公众账号,例如:cjscwe_2015   目录 全栈 编程语言 前端开发 移动开发 数据库 操 ...

  7. MacOS VMware Function安装win的ghost系统(亲测成功!!!)

    1.下载WEPE工具生成可启动ISO 下载WEPE工具 WEPE工具下载地址 下载完成之后,双击打开文件(无需安装,可直接制作可启动ISO) 点击立即生成ISO之后 2.将生成的可启动ISO文件和wi ...

  8. VC++中GDI和GDI+ 的坐标系统介绍

    在Windows应用程序中,只要进行绘图,就要使用GDI坐标系统.Windows提供了几种映射方式,每一种映射都对应着一种坐标系.例如,绘制图形时,必须给出图形各个点在客户区的位置,其位置用x 和y两 ...

  9. 神器与经典--sp_helpIndex

    ======================================================= 每每和那些NB的人学习技术的时候,往往都佩服他们对各个知识点都熟捻于心,更佩服的是可以在 ...

  10. ES6——数据结构 Map

    数据结构 Map 字典: 用来存储不重复key的 Hash结构.不同于集合(Set)的是,字典使用的是 [键,值] 的形式来存储数据的. JavaScript 的对应那个(Object:{}) 只能用 ...