摘要:中的是語言中的一個(gè)關(guān)鍵字它是函數(shù)運(yùn)行時(shí),在函數(shù)體內(nèi)部自動生成的一個(gè)對象,只能在函數(shù)體內(nèi)部使用。情況一純粹的函數(shù)調(diào)用這是函數(shù)的最常通用法,屬于全局性調(diào)用,因此就代表全局對象。因此,這時(shí)運(yùn)行結(jié)果為,證明指的是全局對象。
JS JavaScript中的this
this是JavaScript語言中的一個(gè)關(guān)鍵字
它是函數(shù)運(yùn)行時(shí),在函數(shù)體內(nèi)部自動生成的一個(gè)對象,只能在函數(shù)體內(nèi)部使用。
function test() { this.x = 1; }
那么,this的值是什么呢?
函數(shù)在不同使用場合,this有不同的值。總之,this就是函數(shù)運(yùn)行時(shí)所在的環(huán)境對象。
這是函數(shù)的最常通用法,屬于全局性調(diào)用,因此this就代表全局對象。
var x = 1; function test() { console.log(this.x); } test(); // 1
函數(shù)還可以作為某個(gè)對象的方法調(diào)用,這時(shí)this就指這個(gè)上級對象
function test() { console.log(this.x); } var obj = {}; obj.x = 1; obj.m = test; obj.m(); // 1
構(gòu)造函數(shù)就是通過這個(gè)函數(shù)可以生成一個(gè)新對象。這時(shí),this就指這個(gè)新對象
function test() { this.x = 1; } var obj = new test(); obj.x // 1
為了表明這時(shí)this不是全局對象,下面代碼:
var x = 2; function test() { this.x = 1; } var obj = new test(); x // 2
運(yùn)行結(jié)果為2,表明全局變量x的值沒有變化
apply()是函數(shù)的一個(gè)方法,作用是改變函數(shù)的調(diào)用對象。它的第一個(gè)參數(shù)就表示改變后的調(diào)用這個(gè)函數(shù)的對象。因此,這時(shí)this指的就是這個(gè)參數(shù)。
var x = 0; function test() { console.log(this.x); } var obj = {}; obj.x = 1; obj.m = test; obj.m.apply() // 0
apply()的參數(shù)為空時(shí),默認(rèn)調(diào)用全局變量。因此,這時(shí)運(yùn)行結(jié)果為0,證明this指的是全局對象。
如果把最后一行代碼修改成
obj.m.apply(obj); //1
運(yùn)行結(jié)果就變成1,證明這時(shí)this代表的對象是obj
改變this的指向有以下幾種方法使用ES6的箭頭函數(shù)
在函數(shù)內(nèi)部_this=this
使用apply、call、bind
new實(shí)例化一個(gè)對象
其實(shí)this的指向,始終堅(jiān)持一個(gè)原理:this永遠(yuǎn)指向最后調(diào)用它的那個(gè)對象。
var name = "windowsName"; function a() { var name = "Cherry"; console.log(this.name); // windowsName console.log("inner:" + this); // inner: Window } a(); console.log("outer:" + this) // outer: Window
這里我們使用嚴(yán)格模式,如果使用嚴(yán)格模式的話,全局對象就是 undefined,那么就會報(bào)錯(cuò) Uncaught TypeError: Cannot read property "name" of undefined。
var name = "windowsName"; var a = { name: "Cherry", fn : function () { console.log(this.name); // Cherry } } a.fn();
var name = "windowsName"; var a = { name: "Cherry", fn : function () { console.log(this.name); // Cherry } } window.a.fn();
var name = "windowsName"; var a = { // name: "Cherry", fn : function () { console.log(this.name); // undefined } } window.a.fn();
var name = "windowsName"; var a = { name : null, // name: "Cherry", fn : function () { console.log(this.name); // windowsName } } var f = a.fn; f();
為什么不是 Cherry,這是因?yàn)殡m然將 a 對象的 fn 方法賦值給變量 f 了,“this 永遠(yuǎn)指向最后調(diào)用它的那個(gè)對象”,由于剛剛的 f 并沒有調(diào)用,所以 fn() 最后仍然是被 window 調(diào)用的。所以 this 指向的也就是 window。
例6:
var name = "windowsName"; function fn() { var name = "Cherry"; innerFunction(); function innerFunction() { console.log(this.name); // windowsName } } fn()
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/101264.html
摘要:理解的函數(shù)基礎(chǔ)要搞好深入淺出原型使用原型模型,雖然這經(jīng)常被當(dāng)作缺點(diǎn)提及,但是只要善于運(yùn)用,其實(shí)基于原型的繼承模型比傳統(tǒng)的類繼承還要強(qiáng)大。中文指南基本操作指南二繼續(xù)熟悉的幾對方法,包括,,。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。 怎樣使用 this 因?yàn)楸救藢儆趥吻岸耍虼宋闹兄豢炊?8 成左右,希望能夠給大家?guī)韼椭?...(據(jù)說是阿里的前端妹子寫的) this 的值到底...
摘要:和類在開始時(shí)遇到類組件,只是需要有關(guān)類的基礎(chǔ)。畢竟,中的條件呈現(xiàn)僅再次顯示大多數(shù)是而不是特定的任何內(nèi)容。 在我的研討會期間,更多的材料是關(guān)于JavaScript而不是React。其中大部分歸結(jié)為JavaScript ES6以及功能和語法,但也包括三元運(yùn)算符,語言中的簡寫版本,此對象,JavaScript內(nèi)置函數(shù)(map,reduce,filter)或更常識性的概念,如:可組合性,可重用...
摘要:對象在中,除了數(shù)字字符串布爾值這幾個(gè)簡單類型外,其他的都是對象。那么在函數(shù)對象中,這兩個(gè)屬性的有什么區(qū)別呢表示該函數(shù)對象的原型表示使用來執(zhí)行該函數(shù)時(shí)這種函數(shù)一般成為構(gòu)造函數(shù),后面會講解,新創(chuàng)建的對象的原型。這時(shí)的函數(shù)通常稱為構(gòu)造函數(shù)。。 本文原發(fā)于我的個(gè)人博客,經(jīng)多次修改后發(fā)到sf上。本文仍在不斷修改中,最新版請?jiān)L問個(gè)人博客。 最近工作一直在用nodejs做開發(fā),有了nodejs,...
摘要:所以相同點(diǎn)是,在全局范圍內(nèi),全局變量終究是屬于老大的。只生效一次引入了。只生效一次在箭頭函數(shù)中,與封閉詞法環(huán)境的保持一致。我通常把這些原始函數(shù)叫做構(gòu)造函數(shù)。在里面你可以嵌套函數(shù),也就是你可以在函數(shù)里面定義函數(shù)。 showImg(https://img-blog.csdnimg.cn/20190522000008399.jpg?x-oss-process=image/watermark,...
摘要:原文許多人被中的關(guān)鍵字給困擾住了,我想混亂的根源來自人們理所當(dāng)然地認(rèn)為中的應(yīng)該像中的或中的一樣工作。盡管有點(diǎn)難理解,但它的原理并不神秘。在瀏覽器中,全局對象是對象。運(yùn)算符創(chuàng)建一個(gè)新對象并且設(shè)置函數(shù)中的指向調(diào)用函數(shù)的新對象。 原文:Understanding the this keyword in JavaScript 許多人被JavaScript中的this關(guān)鍵字給困擾住了,我想混亂的...
閱讀 3670·2023-04-26 02:07
閱讀 3176·2021-09-22 15:55
閱讀 2547·2021-07-26 23:38
閱讀 3126·2019-08-29 15:16
閱讀 2017·2019-08-29 11:16
閱讀 1759·2019-08-29 11:00
閱讀 3599·2019-08-26 18:36
閱讀 3169·2019-08-26 13:32