update:伪数组arguments

This commit is contained in:
qianguyihao
2019-02-03 21:22:50 +08:00
parent d0841f9a94
commit 8f4d5e7524
3 changed files with 58 additions and 83 deletions

View File

@@ -89,10 +89,9 @@
ES6中的箭头函数并不会使用上面四条标准的绑定规则而是会继承外层函数调用的this绑定无论this绑定到什么
## 类数组 arguments
## arguments待定
> 这部分,小白可能看不懂。所以,这一段,可以忽略。
> 这部分,小白可能看不懂。所以,这一段,暂时可以忽略。
在调用函数时,浏览器每次都会传递进两个隐含的参数:
@@ -100,6 +99,7 @@ ES6中的箭头函数并不会使用上面四条标准的绑定规则而是
- 2.**封装实参的对象** arguments
例如:
```javascript
@@ -111,19 +111,47 @@ ES6中的箭头函数并不会使用上面四条标准的绑定规则而是
foo();
```
![](http://img.smyhvae.com/20180315_0903.png)
arguments是一个类数组对象它也可以通过索引来操作数据也可以获取长度。
在调用函数时我们所传递的实参都会在arguments中保存。
arguments是一个类数组对象它可以通过索引来操作数据也可以获取长度。
**arguments代表的是实参**。在调用函数时我们所传递的实参都会在arguments中保存。有个讲究的地方是arguments**只在函数中使用**。
### 1、返回函数**实参**的个数arguments.length
arguments.length可以用来获取**实参的长度**。
举例:
```javascript
fn(2,4);
fn(2,4,6);
fn(2,4,6,8);
function fn(a,b) {
console.log(arguments);
console.log(fn.length); //获取形参的个数
console.log(arguments.length); //获取实参的个数
console.log("----------------");
}
```
打印结果:
![](http://img.smyhvae.com/20180125_2140.png)
我们即使不定义形参也可以通过arguments来使用实参只不过比较麻烦arguments[0] 表示第一个实参、arguments[1] 表示第二个实参...
### 2、返回正在执行的函数arguments.callee
arguments里边有一个属性叫做callee这个属性对应一个函数对象就是当前正在指向的函数对象。
arguments里边有一个属性叫做callee这个属性对应一个函数对象就是当前正在指向的函数对象。
```javascript
function fun() {
@@ -134,6 +162,23 @@ arguments里边有一个属性叫做callee这个属性对应一个函数对
fun("hello");
```
在使用函数**递归**调用时推荐使用arguments.callee代替函数名本身。
### 3、arguments可以修改元素
之所以说arguments是伪数组是因为**arguments可以修改元素但不能改变数组的长短**。举例:
```javascript
fn(2,4);
fn(2,4,6);
fn(2,4,6,8);
function fn(a,b) {
arguments[0] = 99; //将实参的第一个数改为99
arguments.push(8); //此方法不通过,因为无法增加元素
}
```
## 我的公众号