日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

阮一峰的JavaScript 的 this 原理

發布時間:2025/3/12 javascript 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 阮一峰的JavaScript 的 this 原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、問題的由來

學懂 JavaScript 語言,一個標志就是理解下面兩種寫法,可能有不一樣的結果。

var obj = {foo: function () {} };var foo = obj.foo;// 寫法一 obj.foo()// 寫法二 foo()

上面代碼中,雖然obj.foo和foo指向同一個函數,但是執行結果可能不一樣。請看下面的例子。

var obj = {foo: function () { console.log(this.bar) },bar: 1 };var foo = obj.foo; var bar = 2;obj.foo() // 1 foo() // 2

這種差異的原因,就在于函數體內部使用了this關鍵字。很多教科書會告訴你,this指的是函數運行時所在的環境。對于obj.foo()來說,foo運行在obj環境,所以this指向obj;對于foo()來說,foo運行在全局環境,所以this指向全局環境。所以,兩者的運行結果不一樣。

這種解釋沒錯,但是教科書往往不告訴你,為什么會這樣?也就是說,函數的運行環境到底是怎么決定的?舉例來說,為什么obj.foo()就是在obj環境執行,而一旦var foo = obj.foo,foo()就變成在全局環境執行?

本文就來解釋 JavaScript 這樣處理的原理。理解了這一點,你就會徹底理解this的作用。

二、內存的數據結構

JavaScript 語言之所以有this的設計,跟內存里面的數據結構有關系。

var obj = { foo: 5 };

上面的代碼將一個對象賦值給變量obj。JavaScript 引擎會先在內存里面,生成一個對象{ foo: 5 },然后把這個對象的內存地址賦值給變量obj。

也就是說,變量obj是一個地址(reference)。后面如果要讀取obj.foo,引擎先從obj拿到內存地址,然后再從該地址讀出原始的對象,返回它的foo屬性。

原始的對象以字典結構保存,每一個屬性名都對應一個屬性描述對象。舉例來說,上面例子的foo屬性,實際上是以下面的形式保存的。

{foo: {[[value]]: 5[[writable]]: true[[enumerable]]: true[[configurable]]: true} }

注意,foo屬性的值保存在屬性描述對象的value屬性里面。

三、函數

這樣的結構是很清晰的,問題在于屬性的值可能是一個函數。

var obj = { foo: function () {} };

這時,引擎會將函數單獨保存在內存中,然后再將函數的地址賦值給foo屬性的value屬性。

{foo: {[[value]]: 函數的地址...} }

由于函數是一個單獨的值,所以它可以在不同的環境(上下文)執行。

var f = function () {}; var obj = { f: f };// 單獨執行 f()// obj 環境執行 obj.f()

四、環境變量

JavaScript 允許在函數體內部,引用當前環境的其他變量。

var f = function () {console.log(x); };

上面代碼中,函數體里面使用了變量x。該變量由運行環境提供。

現在問題就來了,由于函數可以在不同的運行環境執行,所以需要有一種機制,能夠在函數體內部獲得當前的運行環境(context)。所以,this就出現了,它的設計目的就是在函數體內部,指代函數當前的運行環境。

var f = function () {console.log(this.x); }

上面代碼中,函數體里面的this.x就是指當前運行環境的x。

var f = function () {console.log(this.x); }var x = 1; var obj = {f: f,x: 2, };// 單獨執行 f() // 1// obj 環境執行 obj.f() // 2

上面代碼中,函數f在全局環境執行,this.x指向全局環境的x。

在obj環境執行,this.x指向obj.x。

回到本文開頭提出的問題,obj.foo()是通過obj找到foo,所以就是在obj環境執行。一旦var foo = obj.foo,變量foo就直接指向函數本身,所以foo()就變成在全局環境執行。

?

?

總結:

this是用于在函數體內部,指代函數當前的運行環境。
?

總結

以上是生活随笔為你收集整理的阮一峰的JavaScript 的 this 原理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美高清a | 久99视频| 最全aⅴ番号库网 | 色图综合 | 久操伊人网 | 免费黄在线 | 一区二区三区精彩视频 | 91在线公开视频 | 看毛片视频 | 中文字幕爱爱 | 日韩一区二区三区精品 | 国产精品秘入口18禁麻豆免会员 | 淫综合网 | 亚洲天堂aaa | 欧美久久久久久又粗又大 | 日韩av高清在线播放 | 日本wwwxxxx| 黄色av免费看| 五月婷婷小说 | 羞辱极度绿帽vk | 精品一区二区精品 | 夜夜操夜夜爱 | 欧美精品色 | 日本不卡影院 | 青青草视频国产 | 91国模 | 91久久网 | 日本a在线观看 | 成人免费视频免费观看 | 久久精品视频免费观看 | 伊人蕉 | 美女赤身免费网站 | 男人在线天堂 | 欧美人人爽 | 一级二级三级黄色片 | 不卡的av | 99视频精品免费 | 日本jizz在线观看 | 一本到在线观看 | 波多野吉衣av | 国产精品一区二区三区免费看 | 4438x在线观看 | 一区二区高清视频 | 越南黄色一级片 | 国产一区二区综合 | 国产一卡二 | 成人蜜桃av | 91美女免费看 | 国产51页 | 亚洲一区二区三区免费观看 | 国产三级福利 | 欧美丝袜视频 | 亚洲精品国产精品乱码不99热 | 国产又粗又黄又猛 | 已婚少妇美妙人妻系列 | 国产微拍精品一区 | 91网在线播放| 91中文| 在线观看日本 | 国产综合福利 | av男人的天堂av | 视频一区 中文字幕 | 亚洲第一自拍 | 九九av在线 | 夜色精品| 天天狠天天操 | 在线一区二区观看 | 亚洲精品日日夜夜 | 直接看的av | 香港三级日本三级 | 精品久久久999 | 国产精品视频免费 | 特黄视频免费看 | 欧美日韩在线视频免费播放 | 国产精品久久久久久久免费看 | 蜜臀av性久久久久蜜臀aⅴ麻豆 | 亚洲视频自拍偷拍 | 日韩乱码在线观看 | 韩国久久久久 | 91少妇丨porny丨 | 色婷婷精品 | 国内91视频 | 国产成人精品白浆久久69 | porn麻豆 | 日韩区在线| 国产精品xxx在线 | 羞羞色院91蜜桃 | 亚洲精品中文字幕在线播放 | 少妇特殊按摩高潮惨叫无码 | 日韩欧美视频在线 | 琪琪秋霞午夜被窝电影网 | 日韩欧美三区 | 日韩精品第一 | 成人影视网址 | 麻豆传媒视频入口 | 99视频网址 | 国产自在线 | 337p亚洲精品色噜噜狠狠 | 污视频91 |