js的this对象相关

Posted 西门本不吹雪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js的this对象相关相关的知识,希望对你有一定的参考价值。

 1 var scope = ‘globe‘
 2 function log() {
 3     // console.log(this)
 4     let arg  = Array.prototype.join.call(arguments, ‘, ‘);
 5     console.log(`${this.scope}: ${arg}`);
 6 }
 7 let obj = {
 8     scope: ‘own‘,
 9     lop: function() {
10         let scope = ‘scope‘;
11         log(‘low‘)
12     }
13 }
14 obj.lop(); // globe: low
15 obj.lop.call(obj); // globe: low
16 log.call(obj, ‘create‘) // own: create

如果把var scope= ‘globe’ 为 let scope = ‘globe’,结果就是

obj.lop(); // undefined: low
obj.lop.call(obj); // undefined: low
log.call(obj, ‘create‘) // own: create
 
这里分析一下:
  1. log不是作为对象的方法调用的,所以this指向全局对象wondow(这里不考虑nodejs),所以obj.lop()与obj.lop.call(obj)的结果是一样的
  2. 使用var声明scope时,它会被挂在window上,所以使用this可以取到,但是,使用let时,文件相当于一个模块,有局部作用域,scope就不挂在window上了。
  3. log.call(obj, ‘create‘)使用call绑定this值,所以this指向obj

PS: 绑定this方法: call 参数是分开的,apply 参数是数组,bind 绑定this后修改this就没有作用了。

以上是关于js的this对象相关的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段9——JS中的面向对象编程

js的this对象相关

js对象的相关操作方法

js代码片段

VSCode自定义代码片段12——JavaScript的Promise对象

VSCode自定义代码片段12——JavaScript的Promise对象