JavaScript中this指向的四种情况具体是怎样的?

2026-04-09 05:130阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1070个文字,预计阅读时间需要5分钟。

JavaScript中this指向的四种情况具体是怎样的?

对许多前端开发者来说,JavaScript 中的 `this` 指向是一个让人头疼的问题。先看看下面这道测试题,如果你能实现并解释原因,那这篇文章对你来说价值不菲。

测试题:

javascriptfunction test() { console.log(this);}

test();

直接输出结果。

对很多前端开发者来说,JavaScript语言的this指向是一个令人头疼的问题。先看下面这道测试题,如果你能实现并解释原因,那本文对你来说价值不大,可以直接略过。

**开篇测试题:**尝试实现注释部分的Javascript代码,可在其他任何地方添加更多代码(如不能实现,说明一下不能实现的原因):

let Obj = function (msg) { this.msg = msg this.shout = function () { alert(this.msg) } this.waitAndShout = function () { // 隔5秒后执行上面的shout方面 setTimeout(function () { let self = this return function () { self.shout() } }.call(this), 5000) } }

题目的参考答案在文末,但我不建议你直接查看答案,而是先阅读并思考文章的中的知识点。

阅读全文
标签:4

本文共计1070个文字,预计阅读时间需要5分钟。

JavaScript中this指向的四种情况具体是怎样的?

对许多前端开发者来说,JavaScript 中的 `this` 指向是一个让人头疼的问题。先看看下面这道测试题,如果你能实现并解释原因,那这篇文章对你来说价值不菲。

测试题:

javascriptfunction test() { console.log(this);}

test();

直接输出结果。

对很多前端开发者来说,JavaScript语言的this指向是一个令人头疼的问题。先看下面这道测试题,如果你能实现并解释原因,那本文对你来说价值不大,可以直接略过。

**开篇测试题:**尝试实现注释部分的Javascript代码,可在其他任何地方添加更多代码(如不能实现,说明一下不能实现的原因):

let Obj = function (msg) { this.msg = msg this.shout = function () { alert(this.msg) } this.waitAndShout = function () { // 隔5秒后执行上面的shout方面 setTimeout(function () { let self = this return function () { self.shout() } }.call(this), 5000) } }

题目的参考答案在文末,但我不建议你直接查看答案,而是先阅读并思考文章的中的知识点。

阅读全文
标签:4