- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我注意到,似乎没有明确解释this
关键字是什么,以及如何在Stack Overflow网站上的JavaScript中正确(和不正确地)使用它。
我目睹了它的一些非常奇怪的行为,并且未能理解为什么会发生它。this
如何工作,何时应使用?
最佳答案
我建议先阅读Mike West的文章Scope in JavaScript(mirror)。这是对JavaScript中this
和作用域链的概念的出色而友好的介绍。
一旦开始习惯this
,规则实际上非常简单。 ECMAScript 5.1 Standard定义this
:
§11.1.1 this
关键字
this
关键字的值等于当前执行上下文的ThisBinding的值
这个绑定是JavaScript解释器在评估JavaScript代码时所维护的,例如特殊的CPU寄存器,其中包含对对象的引用。每当在以下三种情况之一中建立执行上下文时,解释器都会更新ThisBinding:
1.初始全局执行上下文
在顶层评估的JavaScript代码就是这种情况,例如直接在<script>
内部时:
<script>
alert("I'm evaluated in the initial global execution context!");
setTimeout(function () {
alert("I'm NOT evaluated in the initial global execution context.");
}, 1);
</script>
window
(
§10.4.1.1)。
eval()
eval()
eval()
的含义。基本上,
eval(...)
是直接调用,而类似
(0, eval)(...)
或
var indirectEval = eval; indirectEval(...);
的东西是对
eval()
的间接调用。有关何时可以使用间接
eval()
调用的信息,请参见
chuckj's answer至
(1, eval)('this') vs eval('this') in JavaScript?和
Dmitry Soshnikov’s ECMA-262-5 in detail. Chapter 2. Strict Mode.。
obj.myMethod()
或等效的
obj["myMethod"]()
中)调用了函数,则ThisBinding设置为对象(示例中为
obj
;
§13.2.1)。在大多数其他情况下,ThisBinding设置为全局对象(
§10.4.3)。
thisArg
,当调用函数(
§10.4.3)时,它成为ThisBinding。
Function.prototype.apply( thisArg, argArray )
Function.prototype.call( thisArg [ , arg1 [ , arg2, ... ] ] )
Function.prototype.bind( thisArg [ , arg1 [ , arg2, ... ] ] )
Array.prototype.every( callbackfn [ , thisArg ] )
Array.prototype.some( callbackfn [ , thisArg ] )
Array.prototype.forEach( callbackfn [ , thisArg ] )
Array.prototype.map( callbackfn [ , thisArg ] )
Array.prototype.filter( callbackfn [ , thisArg ] )
Function.prototype
函数,它们是在函数对象上调用的,而不是将ThisBinding设置为函数对象,而是将ThisBinding设置为
thisArg
。
Array.prototype
函数,在执行上下文中调用给定的
callbackfn
,其中,如果提供,则此绑定设置为
thisArg
;否则,转到全局对象。
this
的值。这些JavaScript库的开发人员这样做是因为它倾向于支持最常见的用例,并且该库的用户通常会发现此行为更加方便。将引用
this
的回调函数传递给库函数时,应确保在调用该函数时有关
this
的值的任何保证,请参考文档。
this
的值,则该库仅使用接受
thisArg
的内置JavaScript函数之一。您也可以使用回调函数和
thisArg
编写自己的函数:
function doWork(callbackfn, thisArg) {
//...
if (callbackfn != null) callbackfn.call(thisArg);
}
new
运算符构造新对象时,JavaScript解释器会创建一个新的空对象,设置一些内部属性,然后在新对象上调用构造函数。因此,在构造函数上下文中调用函数时,
this
的值是解释器创建的新对象:
function MyType() {
this.someData = "a string";
}
var instance = new MyType();
// Kind of like the following, but there are more steps involved:
// var instance = {};
// MyType.call(instance);
this
的范围。有关更多信息,请参见现有的规范问题
Arrow function vs function declaration / expressions: Are they equivalent / exchangeable?。简而言之:
this
....绑定。
this
...指的是环境中
this
的值
this
的值是什么?为什么?
window
—在初始全局执行上下文中评估标记的行。
if (true) {
// What is `this` here?
}
this
时,标记行上的
obj.staticFunction()
值是什么?为什么?
obj
—在对象上调用函数时,ThisBinding设置为该对象。
var obj = {
someData: "a string"
};
function myFun() {
return this // What is `this` here?
}
obj.staticFunction = myFun;
console.log("this is window:", obj.staticFunction() == window);
console.log("this is obj:", obj.staticFunction() == obj);
this
的值是什么?为什么?
window
myFun
/
obj.myMethod
,因此ThisBinding设置为
window
。
obj.myMethod
)创建一个
bound method object。
var obj = {
myMethod: function () {
return this; // What is `this` here?
}
};
var myFun = obj.myMethod;
console.log("this is window:", myFun() == window);
console.log("this is obj:", myFun() == obj);
this
的值是什么?为什么?
window
this
为
obj
。但是,在评估代码中,未在对象上调用
myFun
,因此对于该调用,ThisBinding设置为
window
。
function myFun() {
return this; // What is `this` here?
}
var obj = {
myMethod: function () {
eval("myFun()");
}
};
this
的值是什么?为什么?
obj
myFun.call(obj);
行正在调用特殊的内置函数
Function.prototype.call()
,该函数接受
thisArg
作为第一个参数。
function myFun() {
return this; // What is `this` here?
}
var obj = {
someData: "a string"
};
console.log("this is window:", myFun.call(obj) == window);
console.log("this is obj:", myFun.call(obj) == obj);
关于javascript - “this”关键字如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41641439/
如果我创建一个对象时没有使用 new 关键字,例如“Object s(someval)”,但该对象的构造函数使用了 new,当该对象超出范围时,是否会调用析构函数为其分配新的空间?我感觉好像是,但我不
在 SQL 语法中,我发现奇怪的规则表明 select * from ONLY (t1)是有效的 SQL。 我的问题是:什么是 ONLY在这种情况下是什么意思? 它在规范的“7.6 table ref
为什么使用 $(this) 而不是重新选择类很重要? 我在代码中使用了大量的动画和 CSS 编辑,并且我知道可以使用 $(this) 来简化它。 最佳答案 当您通过 jQuery 执行 DOM 查询(
我正在尝试使用 IN 关键字编写查询。 表A 属性标识、属性名称 表B key 、属性标识、属性值 根据提供的 key ,我想返回所有 attrName、attrVal 组合。结果将包含两个表中的列。
这个问题在这里已经有了答案: Why would you use "AS" when aliasing a SQL table? (8 个答案) 关闭 9 年前。 我不擅长写查询,但是从我开始使用
我读过,在 Java 中,您不必将 this 关键字显式绑定(bind)到对象,它由解释器完成。它与 Javascript 相反,在 Javascript 中你总是必须知道 this 的值。但是 Ja
Swift 中“with”关键字的用途是什么?到目前为止,我发现如果您需要覆盖现有的全局函数,例如 toDebugString,可以使用该关键字。 // without "with" you
这个问题在这里已经有了答案: What does the keyword "where" in a class declaration do? (7 个答案) 关闭 9 年前。 在下面的一段代码中(
免责声明:swift 菜鸟 您好,我刚刚开始学习 Swift,正在学习 Swift 编程语言(Apple 在 WWDC 期间发布的书籍),并且想知道“where”关键字是什么。它用于 let vege
深入研究文档后,我找不到以下问题的答案: 是否有任何理由反对使用 this 来引用当前对象,如下例所示? type MyStruct struct { someField string } fun
前言 最近在做THINKPHP开发项目中,用到了 parent:: 关键字,实际上 parent::关键字 是PHP中常要用到的一个功能,这不仅仅是在 THINKPHP 项目开发中,即使是一个小型
我们都知道且经常用到 unsigned 关键字,但有没有想过,与此对应的 signed 关键字有啥用? 复制代码 代码如下: int i = 0; signed
this关键字再java里面是一个我认为非常不好理解的概念,:)也许是太笨的原因 this 关键字的含义:可为以调用了其方法的那个对象生成相应的句柄。 怎么理解这段话呢? thinking i
一 什么是 synchronized synchronized 关键字提供了一种锁机制,能够确保共享变量互斥访问,从而防止数据不一致问题的出现。 synchronized 关键字包括 monitor
最近看了几篇 synchronized 关键字的相关文章,收获很大,想着总结一下该关键字的相关内容。 1、synchronized 的作用 原子性:所谓原子性就是指一个操作或者多个操作,要么全部执行并
在本教程中,您将借助示例了解 JavaScript 对象方法和 this 关键字。 在 JavaScript 中,对象也可以包含函数。例如, // object containing meth
有人可以解释一下 PHP“with”的作用吗? 示例开始: 假设我有一个类: \App\fa_batch 这句话有什么区别: $w = (with (new \App\fa_batch))
这个问题在这里已经有了答案: What is the difference between using the colon and as syntax for declaring type? (2
如果我在 WHERE 子句中使用以下任一项,是否会有很大不同: WHERE [Process Code] = 1 AND ([Material ID] = 'PLT' OR [Material ID]
This question is unlikely to help any future visitors; it is only relevant to a small geographic are
我是一名优秀的程序员,十分优秀!