為什麼 JavaScript 被認為是鬆散型別語言
由於 JavaScript 是一種鬆散類型語言,因此您無需正確預測資料類型 這將保存在一個變數中。取決於您提供給變數的資訊(例如這個‘‘ 或“”表示字串值),JavaScript 將自動鍵入它。變數的型別,例如int, float、boolean 或 String 必須在許多其他語言(包括 Java)中聲明。
這既有好的影響,也有壞的影響。儘管 JavaScript 中的類型系統允許很多 自由,它缺乏高度類型系統的能力,每當您嘗試添加 int 時都會對您大喊大叫 到一個對象,使您不必花費數小時來調試類型錯誤。
JavaScript 的型別是暫時的。函數不需要接受整數作為參數,也不需要 需要明確說明字串就是字串嗎? JavaScript 現在具有很多多功能性。
為了換取更多的安全性和對程式碼庫的信任,你必須放棄一部分 鬆散類型語言帶來的靈活性。
儘管運算子通常會根據 JavaScript 將值轉換為適當的類型 鬆散耦合的型別系統,在某些情況下我們必須進行型別轉換 直接。
儘管 JavaScript 中有許多方法可以在不同類型之間轉換數據,但有兩種 最常做的事 -
- 值轉換為字串
- 值轉換為數字
隱含轉換 - 有許多 JavaScript 運算子和函數可以自動 將值轉換為適當的類型,例如alert()函數,它接受任何值並轉 它到一個字串。但是,某些運算符(例如“ ”運算符)會導致問題。
基本範例
輸入
"4" + "5"
輸出
"45"
在本例中, 運算子代表字串連接。
但是「5」-「3」透過使用隱式轉換給出輸出 2。
範例 1
以下腳本解釋了 JavaScript 如何執行隱式類型轉換。
<!DOCTYPE html> <html> <title>Why is JavaScript considered a loosely-typed language - TutorialsPoint</title> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body style="text-align:center"> <script> document.write('("5" - "3") = ' + ("5" - "3") + "<br>"); document.write('("5" - 3) = ' + ("5" - 3) + "<br>"); document.write('("5" * "2") = ' + ("5" * "2") + "<br>"); document.write('("5" % "2") = ' + ("5" % "2") + "<br>"); document.write('("5" + null) = ' + ("5" + null) + "<br>"); </script> </body> </html>
值到字串的轉換
可以使用toString()或string()函數將JavaScript中的值轉換為字串。
String()函數的語法如下 -
String(value)
範例
let myNumber = 1245; let myString = String(myNumber);
輸出
上面的程式碼將給出以下輸出 -
now myNumber contains "1245"
toString()函數的語法如下 -
variableName.toString(base)
範例
let myNumber = 1245; let myString = toString(myNumber);
輸出
上面的程式碼將給出以下輸出 -
now myNumber contains "1245"
範例 2
數字、布林值和日期都會使用下面的程式碼轉換為字串。
<!DOCTYPE html> <html> <title>Why is JavaScript considered a loosely-typed language - TutorialsPoint</title> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body style="text-align:center"> <script> // The variables myNumber and myDay have been // given the values number and date, respectively. let myNumber = 155; let myDay = new Date('2022-10-31T06:30:00'); // Number to string conversion document.write(" String(myNumber) = " + String(myNumber) + "<br>"); // number to string conversion document.write(" String(myNumber + 15) = " + String(myNumber + 15) + "<br>"); document.write(" String( 20 + 20) = " + String(20 + 20) + "<br>"); // from boolean value to string conversion document.write(" String(false) = " + String(false) + "<br>"); // From Date to string conversion document.write(" String(myDay) = " + String(myDay) + "<br>"); </script> </body> </html>
將值改為數字
可以使用 JavaScript 的 Number() 方法將值轉換為數字。它有能力 將任何數字文字和布林值轉換為數字。當處理字串時 非數字,它將把它們變成 NaN(不是數字)。
文法
Number(valueToConvert)
範例
let myString = "567"; let myNumber = Number(myString);
輸出
上面的程式碼將給出以下輸出 -
now myNumber contain 567(Number)
範例 3
使用下面的程式碼將數字文字、日期和布林值全部轉換為數字。
<!DOCTYPE html> <html> <title>Why is JavaScript considered a loosely-typed language - TutorialsPoint</title> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body style="text-align:center"> <script> // Variables myNumber and myDay, respectively, // have been given the values number and date. let myNumber = "567"; let myDay = new Date('2022-10-31T06:30:00'); // string to number conversion document.write(" Number(myNumber) = " + Number(myNumber) + "<br>"); //A boolean value is converted to a number. document.write(" Number(false) = " + Number(false) + "<br>"); document.write(" Number(true) = " + Number(true) + "<br>"); // Change from date to number document.write(" Number(myDay) = " + Number(myDay) + "<br>"); </script> </body> </html>
範例 4
如果字串不是數字,則將其轉換為 NaN,而空字串或空白字串將轉換為 NaN 到 0。
<!DOCTYPE html> <html> <title>Why is JavaScript considered a loosely-typed language - TutorialsPoint</title> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> </head> <body style="text-align:center"> <script> // Empty string assigned let emptyStr = ""; // White space assigned let whiteSpc = " "; // Non-number string assigned let nonStr = "Welcome to Tutorialspoint!"; // Printing converted values of number document.write(" Number(emptyStr) = " + Number(emptyStr) + "<br>"); document.write(" Number(whiteSpc) = " + Number(whiteSpc) + "<br>"); document.write(" Number(nonStr) = " + Number(nonStr) + "<br>"); </script> </body> </html>
以上是為什麼 JavaScript 被認為是鬆散型別語言的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。
