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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

深入理解javascript原型和闭包(8)——简述【执行上下文】上

發(fā)布時(shí)間:2024/9/16 javascript 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入理解javascript原型和闭包(8)——简述【执行上下文】上 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

什么是“執(zhí)行上下文”(也叫做“執(zhí)行上下文環(huán)境”)?暫且不下定義,先看一段代碼:

第一句報(bào)錯(cuò),a未定義,很正常。第二句、第三句輸出都是undefined,說(shuō)明瀏覽器在執(zhí)行console.log(a)時(shí),已經(jīng)知道了a是undefined,但卻不知道a是10(第三句中)。

在一段js代碼拿過(guò)來(lái)真正一句一句運(yùn)行之前,瀏覽器已經(jīng)做了一些“準(zhǔn)備工作”,其中就包括對(duì)變量的聲明,而不是賦值。變量賦值是在賦值語(yǔ)句執(zhí)行的時(shí)候進(jìn)行的。可用下圖模擬:

這是第一種情況。

下面還有。先來(lái)個(gè)簡(jiǎn)單的。

有js開(kāi)發(fā)經(jīng)驗(yàn)的朋友應(yīng)該都知道,你無(wú)論在哪個(gè)位置獲取this,都是有值的。至于this的取值情況,比較復(fù)雜,會(huì)專(zhuān)門(mén)拿出一篇文章來(lái)講解。
與第一種情況不同的是:第一種情況只是對(duì)變量進(jìn)行聲明(并沒(méi)有賦值),而此種情況直接給this賦值。這也是“準(zhǔn)備工作”情況要做的事情之一。

下面還有。。。第三種情況。
在第三種情況中,需要注意代碼注釋中的兩個(gè)名詞——“函數(shù)表達(dá)式”和“函數(shù)聲明”。雖然兩者都很常用,但是這兩者在“準(zhǔn)備工作”時(shí),卻是兩種待遇。

看以上代碼。“函數(shù)聲明”時(shí)我們看到了第二種情況的影子,而“函數(shù)表達(dá)式”時(shí)我們看到了第一種情況的影子。
沒(méi)錯(cuò)。在“準(zhǔn)備工作”中,對(duì)待函數(shù)表達(dá)式就像對(duì)待“ var a = 10 ”這樣的變量一樣,只是聲明。而對(duì)待函數(shù)聲明時(shí),卻把函數(shù)整個(gè)賦值了。

好了,“準(zhǔn)備工作”介紹完畢。
我們總結(jié)一下,在“準(zhǔn)備工作”中完成了哪些工作:

  • 變量、函數(shù)表達(dá)式——變量聲明,默認(rèn)賦值為undefined;
  • this——賦值;
  • 函數(shù)聲明——賦值;

這三種數(shù)據(jù)的準(zhǔn)備情況我們稱(chēng)之為“執(zhí)行上下文”或者“執(zhí)行上下文環(huán)境”。

這里插一句題外話(huà):通過(guò)以上三種情況,你可能會(huì)聯(lián)想到網(wǎng)上的有些考js語(yǔ)法的題目/面試題。的確,幾乎每個(gè)js語(yǔ)法題中都有這種題目出現(xiàn)。之前你遇到這種題目是不是靠背誦來(lái)解決?背過(guò)了,隔幾天又忘記了。——任何問(wèn)題,都要去追根溯源,要知道這個(gè)問(wèn)題是真正出自哪一塊知識(shí)點(diǎn),要真正去理解。光靠背誦是沒(méi)用的。?

細(xì)心的朋友可能會(huì)發(fā)現(xiàn),我們上面所有的例子都是在全局環(huán)境下執(zhí)行的。
其實(shí),javascript在執(zhí)行一個(gè)代碼段之前,都會(huì)進(jìn)行這些“準(zhǔn)備工作”來(lái)生成執(zhí)行上下文。這個(gè)“代碼段”其實(shí)分三種情況——全局代碼,函數(shù)體,eval代碼。
這里解釋一下為什么代碼段分為這三種。
所謂“代碼段”就是一段文本形式的代碼。
首先,全局代碼是一種,這個(gè)應(yīng)該沒(méi)有非議,本來(lái)就是手寫(xiě)文本到<script>標(biāo)簽里面的。

其次,eval代碼接收的也是一段文本形式的代碼。

最后,函數(shù)體是代碼段是因?yàn)楹瘮?shù)在創(chuàng)建時(shí),本質(zhì)上是 new Function(…) 得來(lái)的,其中需要傳入一個(gè)文本形式的參數(shù)作為函數(shù)體。

這樣解釋?xiě)?yīng)該能理解了。
最后,eval不常用,也不推薦大家用。
下一節(jié)我們介紹函數(shù)的情況,并一起總結(jié)一下執(zhí)行上下文到底包含哪些內(nèi)容。敬請(qǐng)期待。

總結(jié)

以上是生活随笔為你收集整理的深入理解javascript原型和闭包(8)——简述【执行上下文】上的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。