Rumah >hujung hadapan web >tutorial js >Mengapa JavaScript dianggap sebagai bahasa yang ditaip longgar

Mengapa JavaScript dianggap sebagai bahasa yang ditaip longgar

WBOY
WBOYke hadapan
2023-09-05 10:09:03997semak imbas

为什么 JavaScript 被认为是松散类型语言

Memandangkan JavaScript ialah bahasa ditaip secara longgar, anda tidak perlu meramal jenis data dengan betul Ini akan disimpan dalam pembolehubah. Bergantung pada maklumat yang anda berikan kepada pembolehubah (mis. ‘‘ ini atau "" untuk nilai rentetan), JavaScript akan menaipnya secara automatik. Jenis pembolehubah, seperti int, float, boolean, atau String mesti diisytiharkan dalam banyak bahasa lain, termasuk Java.

Ini mempunyai kesan baik dan buruk. Walaupun sistem jenis dalam JavaScript membenarkan banyak Percuma, ia tidak mempunyai kuasa sistem taip tinggi yang akan menjerit kepada anda setiap kali anda cuba menambah int ke objek, menjimatkan anda daripada menghabiskan berjam-jam ralat jenis penyahpepijatan.

Jenis JavaScript adalah sementara. Fungsi ini tidak perlu menerima integer sebagai parameter, dan ia juga tidak memerlukannya Perlu menjelaskan bahawa rentetan ialah rentetan? JavaScript kini mempunyai banyak kepelbagaian.

Sebagai pertukaran untuk lebih keselamatan dan kepercayaan pada asas kod, anda perlu melepaskan beberapa Fleksibiliti yang datang dengan bahasa yang ditaip longgar.

Walaupun pengendali biasanya menukar nilai kepada jenis yang sesuai mengikut JavaScript Sistem jenis yang digandingkan secara longgar, dalam beberapa kes kita perlu melakukan penukaran jenis langsung.

Walaupun terdapat banyak cara untuk menukar data antara jenis yang berbeza dalam JavaScript, terdapat dua Perkara yang paling biasa dilakukan -

  • Tukar nilai kepada rentetan
  • Tukar nilai kepada nombor

Penukaran tersirat - Terdapat banyak pengendali dan fungsi JavaScript yang boleh secara automatik Tukar nilai kepada jenis yang sesuai, seperti fungsi alert(), yang menerima sebarang nilai dan menukar kepada rentetan. Walau bagaimanapun, sesetengah pengendali, seperti pengendali "+", boleh menyebabkan masalah.

Contoh asas

Masuk

"4" + "5"

Output

"45"

Dalam kes ini, operator + mewakili gabungan rentetan.

Tetapi "5" - "3" memberikan output 2 dengan menggunakan penukaran tersirat.

Contoh 1

Skrip berikut menerangkan cara JavaScript melaksanakan penukaran jenis tersirat.

<!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>

Nilai kepada penukaran rentetan

Anda boleh menukar nilai dalam JavaScript kepada rentetan menggunakan fungsi toString() atau string().

Sintaks fungsi

String() adalah seperti berikut -

String(value)

Contoh

let myNumber = 1245;
let myString = String(myNumber);

Output

Kod di atas akan memberikan output berikut -

now myNumber contains "1245"
Sintaks fungsi

toString() adalah seperti berikut -

variableName.toString(base)

Contoh

let myNumber = 1245;
let myString = toString(myNumber);

Output

Kod di atas akan memberikan output berikut -

now myNumber contains "1245"

Contoh 2

Nombor, boolean dan tarikh semuanya akan ditukar kepada rentetan menggunakan kod di bawah.

<!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>

Tukar nilai kepada nombor

Anda boleh menggunakan kaedah Number() JavaScript untuk menukar nilai kepada nombor. ia mempunyai kemampuan Tukar sebarang nilai literal dan boolean berangka kepada nombor. Apabila memproses rentetan bukan nombor, ia akan mengubahnya menjadi NaN (bukan nombor).

Tatabahasa

Number(valueToConvert)

Contoh

let myString = "567";
let myNumber = Number(myString);

Output

Kod di atas akan memberikan output berikut -

now myNumber contain 567(Number)

Contoh 3

Gunakan kod di bawah untuk menukar teks berangka, tarikh dan nilai boolean semuanya kepada nombor.

<!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>

Contoh 4

Jika rentetan itu bukan nombor, ia ditukar kepada NaN, manakala rentetan kosong atau kosong ditukar kepada NaN kepada 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>

Atas ialah kandungan terperinci Mengapa JavaScript dianggap sebagai bahasa yang ditaip longgar. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:tutorialspoint.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam