为什么在HTML中使用onClick()是一种不好的实践?


在本教程中,我们将学习为什么在HTML中使用onClick()是一种不好的实践。

JavaScript中有一些事件和方法可以处理点击、悬停等操作。onClick()是最常用的方法,它在点击元素时执行一个函数。此方法作为属性应用于元素。它可能包含函数名或脚本本身。

JavaScript还包含addEventListener方法,用于在事件发生时执行函数。执行事件的方法有很多,每种方法都有其优点和缺点。

因此,让我们看看为什么在HTML中使用onClick()是一种不好的实践。

在HTML中使用onClick()是一种不好的实践

HTML中的onClick()是作为属性提供给元素的一种方法。它的值可以是JavaScript函数或在该元素上发生点击事件后执行的脚本。但是此方法有一些缺点,这就是为什么它被认为是一种不好的实践。

以下是一些使HTML中的onClick()成为不良实践的原因:

降低代码可读性

在HTML元素中使用onClick()方法会降低代码的可读性,并使其难以管理。此函数接受JavaScript作为其值,该值可以是函数名或脚本本身。因此,当查找使用JavaScript的代码时,我们必须查看所有包含onClick()方法的元素。这使得程序更难以理解。

函数应全局创建

如果我们在元素的onClick()方法内声明了一个函数,则该函数应在JavaScript中全局创建。为每个使用onClick()的元素创建全局函数会导致全局语句污染,应避免这种情况。创建多个全局语句后,很难确定哪个函数属于哪个元素。

导致性能下降

onClick()方法甚至会影响程序的性能。使用onClick()方法声明元素会创建许多需要时间执行的全局函数。添加的onClick()元素越多,程序执行时间就越长。

用户可以按照以下语法查看onClick()方法的使用方式:

语法

<button onclick="func()"> </button>
<script>
   function func(){
      <Write the program here>
   }
</script>

按照上述语法使用onclick()方法。

示例

我们在下面的示例中对每个文档元素都使用了onclick方法。点击元素将执行该函数。这就是为什么脚本中创建了四个函数的原因。每个函数都将为点击单个元素而执行。但是,此程序难以阅读和维护,因为我们必须找到具有指定函数名的元素才能更改代码。每个声明的函数都是全局的,并且在某些情况下也可能产生意外行为。此外,如果函数不断增加,它还会增加程序的执行时间。

<html>
<body>
   <h2 onclick="func3()"> Using <i> onClick() method </i> to execute on onclick event on element </h2>
   <p onclick="func1()"> This is Demo Text! </p>
   <input type="text" id="Text" name="Text" value="" onclick="func()" />
   <button onclick="func2()"> Click me </button>
   <p id="para"> </p>
</body>
<script>
   document.getElementById('para').style.color = "red";
   function func() {
     document.getElementById('para').innerHTML = 'Clicked on a input field';
   }
   function func1() {
     document.getElementById('para').innerHTML = 'Clicked on a paragraph';
   }
   function func2() {
     document.getElementById('para').innerHTML = 'Clicked on a button';
   }
   function func3() {
     document.getElementById('para').innerHTML = 'Clicked on a heading';
   }
</script>
</html>

在上面的示例中,用户可以看到我们使用了onclick方法在点击元素时执行函数。尝试点击文本“This is Demo Text!”、输入字段和按钮“Click me”来执行onclick事件。

onClick()方法的替代方法

如果在一个文档中的单个元素上使用onClick(),则没有问题。但是,如果必须使用addEventListener在各种元素上添加点击事件,则这是一种更好的方法。addEventListener接受两个参数,其中一个是必须添加的事件,第二个是函数或其名称。我们可以在addEventListener方法的第一个参数内添加所有事件。

所有用户都可以按照以下语法在JavaScript中使用addEventListener:

语法

var element = document.getElementById( <Enter element Id> );
element.addEventListener("click", func);
function func(){ 
   <Your script here>
}

按照上述语法在JavaScript中使用addEventListener。

示例

在示例中,我们使用了addEventListener()方法在点击元素时执行函数。我们将从用户那里获取一个字符串输入,并将其分解成一个数组,以使用sort()方法将其按升序和降序排列。

<html>
<body>
   <h2> Using <i> addEventListener method </i> to execute click event </h2>
   <label for="input"> Add a string: </label>
   <input type="text" id="input" name="Input" value="" />
   <button id="btn"> Submit </button>
   <p id="para" style="color: red;"> </p>
   <p id="para1" style="color: red;"> </p>
   <script>
      document.getElementById("btn").addEventListener("click", () => {
         var value = document.getElementById('input').value;
         var array = value.split('');
         var sort = array.sort();
         document.getElementById('para').innerHTML = "After sorting in ascending order: " + sort;
         var rsort = array.sort().reverse();
         document.getElementById('para1').innerHTML = "After sorting in decending order: " + rsort;
      })
   </script>
</body>
</html>

在上面的示例中,用户可以看到我们使用了addEventListener方法在点击元素时在JavaScript中执行点击事件。

在本教程中,我们学习了为什么在HTML中使用onClick()是一种不好的实践,以及其点击事件的替代方法。

更新于:2022年12月6日

6000+ 次浏览

启动你的职业生涯

通过完成课程获得认证

开始
广告