当前位置: 首页 > 面试题库 >

jQuery.click()与onClick

孟嘉歆
2023-03-14
问题内容

我有一个庞大的jQuery应用程序,并且我将以下两种方法用于点击事件。

第一种方法

HTML

<div id="myDiv">Some Content</div>

jQuery

$('#myDiv').click(function(){
    //Some code
});

第二种方法

HTML

<div id="myDiv" onClick="divFunction()">Some Content</div>

JavaScript函数调用

function divFunction(){
    //Some code
}

我在应用程序中使用第一种或第二种方法。哪一个更好?性能更好?和标准?


问题答案:

使用$('#myDiv').click(function(){更好的 ,因为它遵循标准的事件注册模型。(jQuery
内部使用addEventListenerattachEvent)。

基本上,以现代方式注册事件是处理事件的简便方法。另外,要为目标注册多个事件侦听器,您可以addEventListener()为同一目标调用。

var myEl = document.getElementById('myelement');

myEl.addEventListener('click', function() {
    alert('Hello world');
}, false);

myEl.addEventListener('click', function() {
    alert('Hello world again!!!');
}, false);

为什么要使用addEventListener? (来自MDN)

addEventListener是注册W3C DOM中指定的事件侦听器的方法。其优点如下:

  • 它允许为一个事件添加多个处理程序。这对于即使使用其他库/扩展也需要正常工作的DHTML库或Mozilla扩展别有用。
  • 当激活侦听器时,它可以使您对相位进行更细粒度的控制(捕获与冒泡)
  • 它适用于任何DOM元素,而不仅仅是HTML元素。

其他方法,例如设置HTML属性,例如:

<button onclick="alert('Hello world!')">

或DOM元素属性,例如:

myEl.onclick = function(event){alert('Hello world');};

很老,很容易被覆盖。

__应避免使用 HTML属性, 因为它会使标记更大且可读性更差。内容/结构和行为的关注点没有很好地分开,因此很难发现错误。

与该问题 DOM元素性质 的方法是,只有一个事件处理程序可以绑定到每个事件的元件。



 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 和之间有什么区别? 上面的代码一起驻留在单独的.js文件中,并且它们都可以正常工作。 问题答案: 两种方法都是正确的,但是它们本身都不是“最佳”的,并且开发人员选择使用这两种方法可能是有原因的。 事件监听器(addEventListener和IE的attachEvent) Internet Explorer的早期版本与几乎所有其他浏览器都不同地实现javascript。对于小于9的版本

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认