更新時(shí)間:2022-02-18 10:36:44 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1043次
簡單來說,類型有助于對可以執(zhí)行常見操作的相似值進(jìn)行分組。根據(jù)我們的數(shù)學(xué)知識(shí),很容易確定可以對序列11、3、67和中的值求和89。同時(shí),我們知道我們不能將下面的序列JS, is, 和中的值相乘cool,但是我們可以很自然地合并它們。數(shù)字和字符串是最流行的類型。
在編程語言中,類型決定了為保存值分配的內(nèi)存量。值的類型還決定了允許對其執(zhí)行的操作和方法。
JavaScript 有六種原語類型:string、number、undefined、null、boolean和symbol。還有一個(gè)復(fù)合類型或object。有趣的是,原始類型是不可變的并且沒有屬性。例如,由于String對象的原因,您可以檢索字符串的長度。代碼像魔術(shù)一樣由解釋器"a".length進(jìn)行評(píng)估。new String("a").length還有對象Number、Boolean和Symbol,它們也將屬性添加到自己的基元中。
JavaScript 中的類型看起來簡單而無用,但了解它們的工作原理很重要。它們有助于更好地理解語言及其行為。
類型是編程語言的主要基礎(chǔ)之一。JavaScript 中的許多執(zhí)行錯(cuò)誤都是類型錯(cuò)誤。例如,當(dāng)我們嘗試將 a 乘以 a 時(shí)number,我們會(huì)以返回string的形式得到一個(gè)靜默錯(cuò)誤。Not a Number您是否曾經(jīng)調(diào)用過函數(shù)并收到錯(cuò)誤undefined is not a function?當(dāng)我們嘗試訪問未定義的屬性時(shí),就會(huì)發(fā)生這種情況。由于 Javascript 無法找到該屬性,因此它返回其默認(rèn)后備值:undefined.
另一個(gè)常見的與類型相關(guān)的錯(cuò)誤是當(dāng)我們嘗試從值為nullor的值更改或訪問屬性時(shí)undefined。請記住,這里沒有構(gòu)造函數(shù)喜歡Undefined或Null拯救我們。我們最終得到一個(gè)錯(cuò)誤。更不用說我們錯(cuò)誤的值類型this并嘗試禁止的東西的所有時(shí)間。
一個(gè)好的類型系統(tǒng)可以幫助我們避免這些常見的錯(cuò)誤。根據(jù)定義,JavaScript 是一種解釋型和動(dòng)態(tài)語言,它要求類型系統(tǒng)在代碼執(zhí)行期間工作。該語言還嘗試通過靜默轉(zhuǎn)換值類型來提供幫助。當(dāng)您嘗試將一個(gè)數(shù)字與包含一個(gè)數(shù)字的 a 相加2時(shí),它對您有利。:sweat_smile:'3'string類型更改或強(qiáng)制是許多開發(fā)人員切換到嚴(yán)格使用===來檢查值的相等性的原因,但它比修復(fù)強(qiáng)制,不是癥狀解釋的要多得多。
本質(zhì)上,JavaScript 中的類型是一個(gè)移動(dòng)的目標(biāo),很難擊中它們。此外,由于語言是弱類型的,并且該類型可能會(huì)改變,因此無法預(yù)測或確保變量類型。
靜態(tài)類型檢查確保程序是正確的,至少在執(zhí)行之前是靜態(tài)的。在 JavaScript 中,還有其他方法可以注釋值類型。它可以避免你對試圖以瘋狂的方式操作不同類型的用戶產(chǎn)生錯(cuò)誤。
下面的代碼計(jì)算 a 的價(jià)格Product。從第 4 行到第 6 行,我們使用Flow注釋定義Product屬性的類型。其余代碼是純 JavaScript,但請注意第 19 行的值不兼容。這是一種賦予您價(jià)值的代碼。幸運(yùn)的是,F(xiàn)low 分析器會(huì)在編寫代碼時(shí)警告您了解潛在的錯(cuò)誤。
/* @flow */
class Product {
name: string
cost: number
tax: number
constructor (name, cost, tax) {
this.name = name
this.cost = cost
this.tax = tax
}
price() {
return this.cost * (1 + this.tax)
}
}
const item = new Product("Banana", 2, "%30")
Flow 批注允許您定義所有不同的原語、 對象、構(gòu)造函數(shù)/類(Date、、Array...),甚至是字面量。有一些高級(jí)類型,比如任何接受所有類型的類型;可以為空或可能,以指示類型或null;以及 類型和接口的聯(lián)合和交集(更多關(guān)于下面的內(nèi)容)。
恕我直言,最強(qiáng)大的注釋是新類型或別名,它們允許您為一組類型命名以獲取專有屬性;定義上下文所關(guān)注的一組非排他性的重要屬性或方法的接口;和泛型。最后一個(gè),允許您定義數(shù)組值的類型或Promise例如結(jié)果的類型。
根據(jù)Kris Jenkins的說法,通過類型定義,可以預(yù)測設(shè)計(jì)問題。返回許多不同類型的函數(shù)可能意味著計(jì)劃中的錯(cuò)誤。新類型的創(chuàng)建有助于程序員定義問題的實(shí)體。在任何情況下,類型注釋都是編寫更安全、更易理解的代碼的好資源。
以上就是關(guān)于“JavaScript類型詳解”的介紹,大家如果對此比較感興趣,想了解更多相關(guān)知識(shí),不妨來關(guān)注一下動(dòng)力節(jié)點(diǎn)的Java在線學(xué)習(xí),里面的課程內(nèi)容從入門到精通,很適合沒有基礎(chǔ)的小伙伴學(xué)習(xí),希望對大家能夠有所幫助。
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請后,顧問老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743