Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

ฉันสามารถขยายข้อผิดพลาด JavaScript ได้หรือไม่ วิธีที่ดีที่สุดในการทำเช่นนั้นคืออะไร?


ข้อผิดพลาด JavaScript สามารถขยายได้โดยการขยายคลาสข้อผิดพลาด วิธีที่ดีที่สุดในการทำเช่นนี้คือการสร้างคลาสข้อผิดพลาดแบบกำหนดเองใหม่ที่ขยายคลาสข้อผิดพลาด JavaScript ในตัว

ต่อไปนี้เป็นรหัสสำหรับขยายข้อผิดพลาดใน JavaScript -

ตัวอย่าง

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style>
   body {
      font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
   }
   .result {
      font-size: 18px;
      font-weight: 500;
      color: rebeccapurple;
   }
</style>
</head>
<body>
<h1>Extend JavaScript Error</h1>
<div class="result"></div>
<button class="Btn">CLICK HERE</button>
<h3>
Click on the above button to create a new error by extending the error class
</h3>
<script>
   let resEle = document.querySelector(".result");
   let sampleEle = document.querySelector(".sample");
   let BtnEle = document.querySelector(".Btn");
   class CustomError extends Error {
      constructor(message) {
         super(message);
         this.name = "Custom Error";
      }
   }
   function test() {
      throw new CustomError("New Error thrown");
   }
   BtnEle.addEventListener("click", () => {
      try {
         test();
      }
      catch (err) {
         resEle.innerHTML += "err.name = " + err.name + "<br>";
         resEle.innerHTML += "err.message = " + err.message + "<br>";
      }
   });
</script>
</body>
</html>

ผลลัพธ์

รหัสข้างต้นจะสร้างผลลัพธ์ต่อไปนี้ -

ฉันสามารถขยายข้อผิดพลาด JavaScript ได้หรือไม่ วิธีที่ดีที่สุดในการทำเช่นนั้นคืออะไร?

เมื่อคลิกปุ่ม 'คลิกที่นี่' -

ฉันสามารถขยายข้อผิดพลาด JavaScript ได้หรือไม่ วิธีที่ดีที่สุดในการทำเช่นนั้นคืออะไร?