add files

This commit is contained in:
qianguyihao
2018-03-15 14:01:25 +08:00
parent d12e94f797
commit de04dd0107
8 changed files with 490 additions and 21 deletions

View File

@@ -191,6 +191,8 @@
在函数作用域中可以访问到全局作用域的变量,在全局作用域中无法访问到函数作用域的变量。
**租用与的上下级关系:**
当在函数作用域操作一个变量时,它会先在自身作用域中寻找,如果有就直接使用(**就近原则**。如果没有则向上一级作用域中寻找直到找到全局作用域如果全局作用域中依然没有找到则会报错ReferenceError。
@@ -243,6 +245,52 @@
## this
解析器在调用函数每次都会向函数内部传递进一个隐含的参数这个隐含的参数就是thisthis指向的是一个对象这个对象我们称为函数执行的 上下文对象。
根据函数的调用方式的不同this会指向不同的对象【重要】
- 1.以函数的形式调用时this永远都是window。比如`fun();`相当于`window.fun();`
- 2.以方法的形式调用时this是调用方法的那个对象
- 3.以构造函数的形式调用时this是新创建的那个对象
- 4.使用call和apply调用时this是指定的那个对象
针对第1和第2条的举例
```javascript
function fun() {
console.log(this.name);
}
var obj1 = {
name: "smyh",
sayName: fun
};
var obj2 = {
name: "vae",
sayName: fun
};
var name = "全局的name属性";
//obj.sayName();
//以函数形式调用this是window
//fun(); //可以理解成 window.fun()
//以方法的形式调用this是调用方法的对象
obj2.sayName();
```
打印结果:`vae`
@@ -267,4 +315,98 @@
```javascript
```
```javascript
```
```javascript
```
```javascript
```
```javascript
```
```javascript
```
```javascript
```