Mengapa JavaScript dianggap sebagai bahasa yang ditaip longgar

WBOY
Lepaskan: 2023-09-05 10:09:03
ke hadapan
900 orang telah melayarinya

为什么 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"
Salin selepas log masuk

Output

"45"
Salin selepas log masuk

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>
Salin selepas log masuk

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)
Salin selepas log masuk

Contoh

let myNumber = 1245;
let myString = String(myNumber);
Salin selepas log masuk

Output

Kod di atas akan memberikan output berikut -

now myNumber contains "1245"
Salin selepas log masuk
Salin selepas log masuk
Sintaks fungsi

toString() adalah seperti berikut -

variableName.toString(base)
Salin selepas log masuk

Contoh

let myNumber = 1245;
let myString = toString(myNumber);
Salin selepas log masuk

Output

Kod di atas akan memberikan output berikut -

now myNumber contains "1245"
Salin selepas log masuk
Salin selepas log masuk

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>
Salin selepas log masuk

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)
Salin selepas log masuk

Contoh

let myString = "567";
let myNumber = Number(myString);
Salin selepas log masuk

Output

Kod di atas akan memberikan output berikut -

now myNumber contain 567(Number)
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:tutorialspoint.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!