欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS 基本概念詳細介紹

 更新時間:2021年10月14日 10:23:01   作者:海擁  
這篇文章主要介紹JS 基本概念,對于初學者來說,Javascript 乍一看似乎很容易,因為它的類似于 C 的語法,但不管它的運行方式如何,對語言 (ESNext) 及其框架所做的不斷變化可能會讓初學者不知所措。下面我們就來看JS 初學者怎么入門吧

許多人在深入研究 Javascript 之前忽略了 Javascript 的理論方面。這些概念幫助我們了解構(gòu)建 Javascript 應(yīng)用程序時所采用的不同路徑和模式。這些模式存在于 JS Land 的每個框架中,因此在學習語言本身之前了解這些概念很有意義。

1、JS的特點

1.1 多范式

Javascript 支持過程式、面向?qū)ο蠛褪录?qū)動的函數(shù)式編程!掌握 JS 的面向?qū)ο缶幊田L格是非常有益的。

面向?qū)ο缶幊炭蓭椭绦騿T更輕松地可視化軟件應(yīng)用程序的組件。此外,學習 Typescript(Javascript with Types)可以讓程序員輕松實現(xiàn)行業(yè)中最好的設(shè)計模式。這些設(shè)計模式用于以最有效的方式解決軟件編程中遇到的最常見問題。

這種多功能性使 Javascript 非常平易近人且非常強大。

1.2 解釋

Javascript C/C++ 不同,它不是一次讀取程序,而是逐行解釋。這就是說 JS 會比 C/C++ 等編譯語言慢。

警告:  Javascript 因在運行時是一種極其被動的語言而臭名昭著,對錯誤進行故障排除非常困難。

不過隨著時間和練習,你將學會如何流暢地運行。最常見的錯誤涉及你的變量返回NULL值。當此類問題確實出現(xiàn)時,請前往 Stack Overflow,因為我向你保證,無論錯誤多么離譜,你都不是第一個遇到錯誤的人。在你的項目進行開發(fā)時自由地使用console.log()也是一個好辦法。這可以幫助您準確找出程序生命周期中的時刻,您的變量可能已經(jīng)脫落。

1.3單線程

Javascript 一次只能執(zhí)行一項任務(wù)。它根據(jù)類型將不同的任務(wù)排隊到不同的隊列中。
在最抽象的意義上,Javascript 基本上會將同步任務(wù)和異步任務(wù)分組,并將它們分開排隊。

同步任務(wù)是在遇到它們時立即處理的語句,即它們立即運行。這些任務(wù)包括日志語句、變量聲明、條件檢查等。

異步任務(wù)涉及可能需要可變時間來返回輸出的任務(wù)。異步任務(wù)的一個示例可能是從 Web API 請求信息。

此外,Javascript 還有一個 Job Queue,用于處理名為 Promises JS Feature。

通過右鍵單擊此網(wǎng)頁并點擊檢查選項卡,您實際上可以看到 Javascript 的單線程特性。接下來,轉(zhuǎn)到剛剛打開的窗口上的控制臺選項卡。輸入以下代碼并按回車鍵。\

while(true) {}


您現(xiàn)在可以觀察到此頁面完全沒有響應(yīng)。這是因為此頁面上的 Javascript 現(xiàn)在正忙于運行我們上面執(zhí)行的無限 while 循環(huán)。

1.4 非阻塞

我們之前已經(jīng)討論過異步任務(wù)。由于 JS 在單線程環(huán)境中運行,默認情況下,它不會進行等待!

異步代碼塊只有在所有同步代碼塊都執(zhí)行完后才會執(zhí)行,而不管代碼在程序中的位置如何。

console.log("我是第一個語句")

setTimeout(()=> {
console.log("我是第二個語句")
},1000)

console.log("我是第三個語句")

這里console.log()將其中的語句記錄到控制臺,setTimeout()函數(shù)在一秒鐘后運行第二條語句。

在檢查輸出時

我是第一個語句
我是第三個語句
我是第二個語句


我們可以看到第三條語句在第二條語句之前記錄。這是因為 JS 處理同步和異步代碼塊的固有方法。

1.5 高級

JavaScript 是一種高級語言。高級語言可能只是意味著它們更接近人類所說的語言。高級語言能夠提供更多功能來幫助程序員更好地表達他們正在嘗試構(gòu)建的內(nèi)容。

Javascript 的這種高級特性有助于它最好地服務(wù)于 Web 的客戶端部分。過去 JS 的一個主要限制是它只能在客戶端提供服務(wù),而不能像大多數(shù)服務(wù)器端語言那樣進行文件操作。

然而,這已經(jīng)改變了NodeJS,允許開發(fā)人員使用 Javascript 來構(gòu)建后端服務(wù)器。因此,只需使用一種語言,軟件開發(fā)人員就可以在服務(wù)器端和客戶端進行操作。這導致全棧工程師變得突出。

1.6 動態(tài)類型

Javascript 也是一種動態(tài)類型語言。這意味著與需要為變量指定數(shù)據(jù)類型的 C 不同,我們可以type-inferenceJavascript 中使用來自動檢測數(shù)據(jù)的類型,變量保存。\

// 在 C 中變量必須有數(shù)據(jù)類型。 為了將數(shù)據(jù)類型從一種類型更改為另一種類型,我們需要使用類型轉(zhuǎn)換
int a = 5;
char b = "a";
float c = 7.036;


Javascript 中,我們使用letconst分別聲明變量或常量。\

let a = 5
console.log(a) // 5
a = 'Hello World'
console.log(a) // Hello World

const b = 'JS 很酷' 
console.log(b) // JS 很酷

b = '我改變主意了'
console.log(b) // Error: const cannot be changed

雖然類型推斷因其易于使用而看起來是一個加分點,但它立即成為需要類型安全作為功能的大型項目的一個騙局。

出于這個原因,較大的項目使用 TypeScript,它只是 Javascript 的包裝器,提供類型、接口和各種其他功能。

2、學習策略

JS Land 中安頓下來需要一段時間,但我有一個簡單的清單,Minimum Requirements用于學習 Express ReactJS 等框架。

首先,不要急于學習這些框架。你需要花點時間掌握 Vanilla Javascript。

3、基礎(chǔ)知識

  • 變量和常量
  • 條件塊(if-else
  • 循環(huán)(for、while、forEach
  • 開關(guān)盒(Switch Case
  • 方法(Functions

高級部分(最低要求)

  • 異步/等待
  • Promises
  • Javascript 中的類
  • Rest/Spread 語法
  • 數(shù)組/對象迭代器
  • 數(shù)組解構(gòu)
  • 模塊(導入、導出)

在構(gòu)建項目時繼續(xù)學習,很快你就會對語言有很強的掌握。

到此這篇關(guān)于JS 基本概念詳細介紹的文章就介紹到這了,更多相關(guān)JS 基本概念內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論