亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一起來了解一下JavaScript的預(yù)編譯(小結(jié))

 更新時間:2021年03月01日 11:56:37   作者:前端布吉島  
這篇文章主要介紹了一起來了解一下JavaScript的預(yù)編譯(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

JS運行三部曲

js運行代碼共分三步

  • 語法分析
  • 預(yù)編譯
  • 解釋執(zhí)行

JavaScript代碼在運行時,首先會進行語法分析,通篇檢查代碼是否存在低級錯誤,然后進行預(yù)編譯,整理內(nèi)部的一個邏輯,最后再開始一行一行的執(zhí)行代碼

語法分析

代碼在執(zhí)行之前,系統(tǒng)會通篇掃描一遍,檢查代碼有沒有低級的語法錯誤,比如少寫個大括號。

預(yù)編譯

預(yù)編譯前奏

預(yù)編譯發(fā)生在函數(shù)執(zhí)行的前一刻。變量未經(jīng)聲明就賦值,此變量為全局對象所有

a = 3

var b = c = 4

一切聲明的全局變量,全是window的屬性

var a = 1 ===> window.a = 1

預(yù)編譯四部曲

  1. 創(chuàng)建AO(Activation Object)對象(里面存儲的是函數(shù)內(nèi)部的局部變量)
  2. 找形參和變量聲明,將變量和形參名做為AO屬性名,值為undefined
  3. 將實參和形參統(tǒng)一
  4. 在函數(shù)體里面找函數(shù)聲明,值賦予函數(shù)體

用一個例子來說明一下,也可以自己先給出一個答案,再繼續(xù)往下看

function fn(a) {
 console.log(a);
 var a = 123;
 console.log(a);
 function a() {}
 console.log(a);
 var b = function() {};
 console.log(b);
 function d() {}
 console.log(d)
}
fn(1);

第一步,創(chuàng)建AO(Activation Object)對象 {}第二步,找形參和變量聲明,將變量和形參名做為AO屬性名,值為undefined

{
 a: undefined,
 b: undefined,
}

第三步,將實參和形參統(tǒng)一

{
 a: 1,
 b: undefined,
}

第四步,找函數(shù)聲明,值賦予函數(shù)體

{
 a: function a() {},
 b: undefined,
 d: function d() {}
}

所以在函數(shù)fn執(zhí)行的前一刻,a、b、d的值如上所示

所以fn(1)執(zhí)行的結(jié)果為

// ƒ a() {}
// 123
// 123
// ƒ () {}
// ƒ d() {}

在全局作用域里,預(yù)編譯過程有些許不同

  • 創(chuàng)建GO(Global Object)對象(里面存儲的是函數(shù)內(nèi)部的全局變量)GO === window
  • 找形參和變量聲明,將變量和形參名做為GO屬性名,值為undefined
  • 在函數(shù)體里面找函數(shù)聲明,值賦予函數(shù)體

解釋執(zhí)行

一行一行的執(zhí)行代碼

實踐題

這里有幾個例題,有興趣的可以看一下

function test(a, b) {
 console.log(a);
 console.log(b);
 var b = 234;
 console.log(b);
 a = 123;
 console.log(a);
 function a() {}
 var a;
 b = 234;
 var b = function() {};
 console.log(a);
 console.log(b);
}
test(1);
global = 100;
function fn() {
 console.log(global);
 global = 200;
 console.log(global);
 var global = 300;
}
fn();
var global;

function test() {
 console.log(b);
 if (a) {
  var b = 100;
 }
 c = 234;
 console.log(c);
}
var a;
test();
a = 10;
console.log(c);

總結(jié)

多數(shù)情況下,我們都是采用下面的這種方式來處理預(yù)編譯的一個過程

  • 函數(shù)聲明,整體提升
  • 變量聲明,聲明提升

若是遇見復(fù)雜的情況就只能采用最原始的方式來解決問題了

到此這篇關(guān)于一起來了解一下JavaScript的預(yù)編譯(小結(jié))的文章就介紹到這了,更多相關(guān)JavaScript 預(yù)編譯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js和php如何獲取當(dāng)前url的內(nèi)容

    js和php如何獲取當(dāng)前url的內(nèi)容

    js和php獲取當(dāng)前url的內(nèi)容在某些特殊的情況下還是蠻實用的,下面有個不錯的示例,感興趣的朋友可以參考下,希望對大家有所幫助
    2013-09-09
  • 最新評論