news 2026/4/15 7:27:45

如何解释JavaScript 中 this 的值?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何解释JavaScript 中 this 的值?

文章目录

  • 如何解释Javascript中的this值?
    • 1.函数调用
    • 2.对象方法调用
    • 3.构造函数调用
    • 4.apply、call、bind 方法调用
    • 5.箭头函数中的this

如何解释Javascript中的this值?

在 JavaScript 中,this的值是动态的,通常会由被使用的函数来决定。所以,影响this的值不是定义的时候,关键在于会在哪里被调用。

this 值 5 种判断方式

  • 函数调用
  • 物体方法调用
  • 构造函数调用
  • apply call bind 方法调用
  • 箭头函数中的 this

1.函数调用

当一个函数不是属于一个对象中的方法时,直接作为函数来调用时,this 会指向全局对象,在浏览器中,默认为 Window。但有一点要注意的是,如果是在严格模式下,this 为 undefined。

例子如下,因为是一般函数调用,this 总是指向 Window,所以一个输出结果是 Window。而因为在全局范围中用 var 定义 name 变量。name 变量会绑定在 Window 对象上,第二个输出结果也就等同于 window.name 的值(如果是用 let 定义,并不会绑定在 Window 对象上)

varname="John";functioncallThis(){console.log(this);console.log(this.name);}callThis();// Window// John

2.对象方法调用

当一个函数是作为一个对象的方法来调用时,this 会指向这个对象

constjohn={name:"john",callJohn(){console.log(`hello,${this.name}`);},};john.callJohn();// hello, john
this 的指向取决于函数被调用的方式,而不是函数定义的位置。 因为使用的时候是 join.xxx,对象调用。

关键反例:

constjohn={name:"john",callJohn(){console.log(this.name);},};constfn=john.callJohn;fn();// undefined(或严格模式下报错)

3.构造函数调用

当一个函数使用 new 调用的时候,会出现如下情况

重点来看this 指针的调用

第一处 this 指针

  • 构造函数执行时,this 指向新创建的 object,所以 this.brand = brand 实际是在给 object 添加属性。

第二处 this 指针

  • 调用 newIPhone.getBrand() 时,因为是对象方法调用,this 自动指向 newIPhone,所以能正确返回该对象的 brand。

4.apply、call、bind 方法调用

我们也可以使用applycallbind方法来指定this指向的对象。

  • apply方法接受两个参数,第一個是 this 绑定的对象,第二个要放入要传入函数的数组参数,并执行这个函数。

  • call方法类似为apply,唯一不同的地方是,apply第二个参数是数组,但call则是参数逐个传。

  • bind方法传入一个对象和要传入的参数,不同于applycallbind不会立即执行,而是会返回新的函数。

举例如下:

functiongreet(greeting,punctuation){console.log(`${greeting}, I am${this.name}${punctuation}`);}constperson={name:"Alice",};

apply —— 立即执行,参数用数组传

greet.apply(person,["Hi","~"]);//Hi, I am Alice~

call —— 立即执行,参数逐个传

greet.call(person,"Hello","!");//Hi, I am Alice~

bind —— 不立即执行,返回一个新函数

const boundGreet = greet.bind(person, "Hey");

此时:

  • this 已经被固定为 person
  • “Hey” 被提前绑定为第一个参数
  • 函数还没执行

执行返回的新函数:

boundGreet("!!!");// Hey, I am Alice!!!

补充知识点:

为什么 bind 常用于事件 / 回调? setTimeout(greet.bind(person, "Hello"), 1000);
因为:setTimeout 会丢失原来的 this bind 可以提前把 this 固定住

5.箭头函数中的this

ES6 中介紹了一种新的函数形式 - 箭头函数(arrow function)。但要注意的是,箭头函数并没有属于自己的this值,箭头函数的this会从他的外层函数继承,若他的外层函数也同为箭头函数 ,則回继续向上找,直到找到全局环境的预设this值(例如:浏览器中就是window)。

let getThis = () => this; console.log(getThis() === window); // true
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 22:42:40

Qwen All-in-One快速体验:Web界面操作完整流程

Qwen All-in-One快速体验:Web界面操作完整流程 1. 轻量全能,一模型多任务的AI新体验 你有没有遇到过这样的问题:想做个情感分析,又想聊聊天,结果发现要装一堆模型——BERT做分类、LLM搞对话,显存爆了不说…

作者头像 李华
网站建设 2026/4/10 1:46:41

Cygwin介绍

文章目录Cygwin介绍,优缺点一、Cygwin 环境介绍核心组成:支持语言与工具:二、Cygwin 的优缺点分析✅ 优点:❌ 缺点:三、在 C 或 Python 中使用 Cygwin 执行命令前提:1. 在 C 中调用 Cygwin 命令方法一&…

作者头像 李华
网站建设 2026/4/11 2:04:12

校园安全监控:用YOLOv10实现异常行为识别

校园安全监控:用YOLOv10实现异常行为识别 在校园安全管理日益受到重视的今天,传统的视频监控系统已难以满足实时、智能、主动预警的需求。大量摄像头产生的海量视频流需要人工轮巡,效率低、易遗漏,尤其在学生聚集区域如走廊、操场…

作者头像 李华
网站建设 2026/4/11 16:43:05

Z-Image-Turbo运行报错?常见异常排查与修复指南

Z-Image-Turbo运行报错?常见异常排查与修复指南 1. 引言:为什么你的Z-Image-Turbo会“卡住”? 你是不是也遇到过这种情况:满怀期待地启动Z-Image-Turbo,输入提示词,按下回车——结果程序直接崩溃、显存爆…

作者头像 李华
网站建设 2026/4/10 11:56:51

Vue.js 前端开发实战之 05-Vue 过渡和动画

过渡和动画基础 过渡和动画概述 Vue 在插入、更新或者移除 DOM 时,提供了多种过渡效果。 过渡,就是从一个状态向另外一个状态插入值,新的状态替换了旧的状态。 Vue 提供了内置的过渡封装组件 transition,可以结合 CSS 动画 ke…

作者头像 李华
网站建设 2026/4/11 15:48:22

5分钟快速搭建:Ubuntu+MySQL开发环境

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个极简MySQL环境快速部署工具,功能要求:1. 单命令完成安装(支持Ubuntu 18.04-22.04) 2. 自动配置开发常用参数(如…

作者头像 李华