小数点儿_ 2023-04-06 11:12 采纳率: 83.3%
浏览 22
已结题

js 中立即执行匿名函数表达式中的 this 指代的是什么

js 中立即执行匿名函数表达式中的 this 指代的是什么,
以下给出一个例子,尽可能举出更多例子来说明

var myObject = {
  foo: "bar",
  func: function () {
    var self = this;
    console.log(this.foo);
    console.log(self.foo);
    (function () {
      console.log(this.foo);
      console.log(self.foo);
    })();
  },
};

myObject.func();
  • 写回答

4条回答 默认 最新

  • usp1994 2023-04-06 11:38
    关注

    在 JS 中,立即执行匿名函数表达式是常见的一种模块化组织代码的方式,常常用于避免全局作用域的变量污染和函数命名冲突。在这种模式下,匿名函数会在定义时立刻执行,通常会使用到闭包。那么,在这种模式下,this 指代的到底是什么呢?

    在立即执行匿名函数表达式中的 this,实际上是指向全局对象(在浏览器中为 window,在 Node.js 中为 global)。这与函数传入的参数、使用的变量以及函数本身的作用域无关。下面是一些例子,以便更好地理解:

    (function() {
      console.log(this); // 指向全局对象
    })();
    
    (function() {
      'use strict';
      console.log(this); // 指向 undefined
    })();
    
    var obj = {
      myMethod: function() {
        console.log(this); // 指向全局对象
      }
    };
    (function() {
      obj.myMethod(); // 指向全局对象
    })();
    
    var obj = {
      myMethod: function() {
        (function() {
          console.log(this) // 指向全局对象
        })();
      }
    };
    obj.myMethod();
    
    var obj = {
      myMethod: function() {
        (function() {
          'use strict';
          console.log(this) // 指向 undefined
        })();
      }
    };
    obj.myMethod();
    

    在上述例子中,this 都指向全局对象(window 或 global)。

    需要注意的是,在使用 this 时需要注意其指向,因为不同的上下文中 this 的指向是不一样的。如果是想绑定特定的上下文对象,可以使用 call、apply、bind 等函数来指定 this 指向。

    总之,在立即执行匿名函数表达式中,this 指代的是全局对象,它不受函数内部上下文的影响。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 4月16日
  • 已采纳回答 4月8日
  • 创建了问题 4月6日

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀