html的鼠标点击事件有哪些写法

在HTML中,鼠标点击事件的实现方式多样,以下从基础语法到现代实践为您详细梳理:

一、基础写法:直接内联事件属性

在HTML标签内通过on前缀事件属性绑定处理函数,适合简单交互场景:

<!-- 单击事件 -->
<button onclick="alert('单击触发')">点击我</button><!-- 双击事件 -->
<h1 ondblclick="showMessage()">双击标题</h1><!-- 右键菜单事件(需配合contextmenu属性) -->
<div oncontextmenu="handleRightClick(event)">右键点击区域</div>

特点:代码直观,但JavaScript与HTML耦合,维护成本高。

二、进阶写法:DOM属性动态绑定

通过JavaScript获取元素后,直接赋值事件处理函数,实现结构与行为分离:

// 获取按钮并绑定单击事件
const btn = document.getElementById("myBtn");
btn.onclick = function() {this.textContent = "已点击";console.log("按钮被单击");
};// 覆盖式绑定(多次赋值会覆盖前次)
btn.onclick = () => alert("新事件处理");

适用场景:简单逻辑分离,但无法为同一元素绑定多个处理函数。

三、现代标准:事件监听器(EventListener)

使用addEventListener方法,支持多事件绑定、事件流控制,是推荐方案:

// 基础用法
const btn = document.querySelector("button");
btn.addEventListener("click", function(e) {e.target.style.background = "red";console.log("点击坐标:", e.clientX, e.clientY);
});// 绑定多个处理函数
btn.addEventListener("click", logClickCount);
btn.addEventListener("click", () => {alert("第二个处理函数触发");
});// 事件委托(动态元素处理)
document.getElementById("parent").addEventListener("click", (e) => {if (e.target.matches(".dynamic-btn")) {handleDynamicClick(e.target);}
});

优势

  • 支持捕获/冒泡阶段控制(第三个参数useCapture
  • 可通过removeEventListener移除特定监听器
  • 兼容现代浏览器及IE9+

四、兼容性处理:旧版IE支持

针对IE8及以下版本,需使用attachEvent方法:

const btn = document.getElementById("legacyBtn");
if (btn.attachEvent) {btn.attachEvent("onclick", function() {alert("IE专属事件绑定");});
} else {btn.addEventListener("click", modernHandler);
}

五、框架集成:React/Vue等现代框架

主流框架封装了事件机制,提供更简洁的语法:

  • React
    <button onClick={() => setState({ clicked: true })}>React按钮
    </button>
    
  • Vue
    <button @click="handleClick">Vue按钮</button>
    

六、高级技巧

  1. 阻止默认行为与冒泡

    element.addEventListener("click", (e) => {e.preventDefault(); // 阻止表单提交等默认行为e.stopPropagation(); // 阻止事件冒泡到父元素
    });
    
  2. 传递自定义参数

    <button onclick="handleEvent('参数1', event)">带参点击</button>
    
    function handleEvent(param, e) {console.log("参数:", param, "事件对象:", e);
    }
    

总结:如何选择?

  • 快速原型/简单页面:内联属性onclick
  • 结构分离需求:DOM属性绑定或addEventListener
  • 复杂交互/动态内容:事件监听器+事件委托
  • 现代框架项目:直接使用框架提供的事件API

通过合理选择事件绑定方式,可平衡开发效率与代码可维护性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/81353.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于EFISH-SCB-RK3576/SAIL-RK3576的智能垃圾分类站技术方案

&#xff08;国产化替代J1900的环保物联网解决方案&#xff09; 一、硬件架构设计‌ ‌多模态感知系统‌ ‌高精度识别模块‌&#xff1a; 双光谱成像&#xff08;RGB近红外&#xff09;融合NPU加速ResNet50模型&#xff0c;支持40垃圾品类识别&#xff08;准确率>99.5%&am…

PYTHON训练营DAY27

装饰器 编写一个装饰器 logger&#xff0c;在函数执行前后打印日志信息&#xff08;如函数名、参数、返回值&#xff09; logger def multiply(a, b):return a * bmultiply(2, 3) # 输出: # 开始执行函数 multiply&#xff0c;参数: (2, 3), {} # 函数 multiply 执行完毕&a…

Android Studio 中 build、assemble、assembleDebug 和 assembleRelease 构建 aar 的区别

上一篇&#xff1a;Tasks中没有build选项的解决办法 概述&#xff1a; 在构建 aar 包时通常会在下面的选项中进行构建&#xff0c;但是对于如何构建&#xff0c;选择哪种方式构建我还是处于懵逼状态&#xff0c;所以我整理了一下几种构建方式的区别以及如何选择。 1. build…

视频质量分析时,遇到不同分辨率的对照视频和源视频,分辨率对齐的正确顺序。

背景 我们平时在做视频转码后&#xff0c;会用VMAF/PSNR得评分工具进行视频对比的评分&#xff0c;但是这几种客观评分方式都有一个要求就是分辨率要一模一样&#xff0c;因为这样才对像素点做数学运算。 但是分辨率对齐其实有两种选择&#xff0c;例如源视频是1080P&#xf…

【技巧】离线安装docker镜像的方法

回到目录 【技巧】离线安装docker镜像的方法 0. 为什么需要离线安装&#xff1f; 第一、 由于docker hub被墙&#xff0c;所以 拉取镜像需要配置国内镜像源 第二、有一些特殊行业服务器无法接入互联网&#xff0c;需要手工安装镜像 1. 可以正常拉取镜像服务器操作 服务器…

计算机网络 : 网络基础

计算机网络 &#xff1a; 网络基础 目录 计算机网络 &#xff1a; 网络基础引言1. 网络发展背景2. 初始协议2.1 初始协议2.2 协议分层2.2.1 软件分层的好处2.2.2 OSI七层模型2.2.3 TCP/IP五层&#xff08;四层&#xff09;模型 2.3 TCP/IP协议2.3.1TCP/IP协议与操作系统的关系&…

【2025最新】Windows系统装VSCode搭建C/C++开发环境(附带所有安装包)

文章目录 为什么选择VSCode作为C/C开发工具&#xff1f;一、VSCode安装过程&#xff08;超简单&#xff01;&#xff09;二、VSCode中文界面设置&#xff08;再也不用对着英文发愁&#xff01;&#xff09;三、安装C/C插件&#xff08;编程必备神器&#xff01;&#xff09;四、…

Jmeter 安装包与界面汉化

Jmeter 安装包&#xff1a; 通过网盘分享的文件&#xff1a;CSDN-apache-jmeter-5.5 链接: https://pan.baidu.com/s/17gK98NxS19oKmkdRhGepBA?pwd1234 提取码: 1234 Jmeter界面汉化&#xff1a;

HandlerInterceptor介绍-笔记

1. HandlerInterceptor简介 org.springframework.web.servlet.HandlerInterceptor 是 Spring MVC 中用于拦截 HTTP 请求的核心接口。 public interface HandlerInterceptor {default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object ha…

C++循环效率比较与优化建议

在 C++ 中,不同循环结构(如 for、while、do-while、基于范围的 for)在优化后的性能通常是等效的,因为现代编译器会对它们进行底层优化,生成相似的机器代码。循环的效率更多取决于循环体内的操作和数据访问模式,而非循环结构本身的选择。以下是关键点总结: 1. 传统循环的…

北京孙河傲云源墅:限量典藏的主城墅居臻品

在限墅令的背景下&#xff0c;北京主城的墅居产品日益稀缺&#xff0c;而傲云源墅作为孙河墅区的杰出之作&#xff0c;凭借其独特的价值&#xff0c;成为了众多高端置业者的理想选择。 傲云源墅所处的孙河地区&#xff0c;是北京公认的高价值板块。其地位在 2025 年孙河 2902 …

简单入门RabbitMQ

本章将带大家来写一个简单的程序&#xff0c;使用 Java 创建RabbitMQ 的生产者和消费者 依赖引入 在 Maven 仓库中输入 amqp-client&#xff1a; 找到第一个 RabbitMQ Java Client &#xff0c;点击进去找到一个合适的版本然后将依赖引入到我们项目中的 pom.xml 文件中。 …

Git基础使用方法与命令总结

Git 是一个分布式版本控制系统&#xff0c;用于跟踪代码或文件的修改历史。以下是 Git 的基础使用方法和常用命令&#xff0c;适合快速上手&#xff1a; 1. 安装与配置 安装 Git 下载地址&#xff1a;https://git-scm.com/downloads&#xff08;支持 Windows/macOS/Linux&…

Oracle SYSTEM/UNDO表空间损坏的处理思路

Oracle SYSTEM/UNDO表空间损坏是比较棘手的故障&#xff0c;通常会导致数据库异常宕机进而无法打开数据库。数据库的打开故障处理起来相对比较麻烦&#xff0c;读者可以参考本书第5章进一步了解该类故障的处理过程。如果数据库没有备份&#xff0c;通常需要设置官方不推荐的隐含…

The Graph:区块链数据索引的技术架构与创新实践

作为Web3生态的核心基础设施&#xff0c;The Graph通过去中心化索引协议重塑了链上数据访问的范式。其技术设计不仅解决了传统区块链数据查询的效率瓶颈&#xff0c;还通过经济模型与多链兼容性构建了一个开放的开发者生态。本文从技术角度解析其架构、机制及创新实践。 一、技…

在24GB显存大小的GPU上运行27GB的Pytorch模型

在24GB显存大小的GPU上运行27GB的Pytorch模型 一.背景:显存不足时的破局之道1.1 大模型时代的显存困境1.2 CUDA统一内存的魔法二.性能测试数据深度解读关键发现:三.复现过程3.1 准备自定义分配器3.2 准备测试程序3.3 执行流程3.4 开始测试四.原理深度剖析4.1 统一内存的工作机…

Spring Boot 参数验证

一、依赖配置 首先确保在 pom.xml 中添加了以下依赖&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId> </dependency> 这个依赖包含了 Hibernate Valida…

SHAP分析!Transformer-GRU组合模型SHAP分析,模型可解释不在发愁!

SHAP分析&#xff01;Transformer-GRU组合模型SHAP分析&#xff0c;模型可解释不在发愁&#xff01; 目录 SHAP分析&#xff01;Transformer-GRU组合模型SHAP分析&#xff0c;模型可解释不在发愁&#xff01;效果一览基本介绍程序设计参考资料 效果一览 基本介绍 基于SHAP分析…

在微创手术中使用Kinova轻型机械臂进行多视图图像采集和3D重建

在微创手术中&#xff0c;Kinova轻型机械臂通过其灵活的运动控制和高精度的操作能力&#xff0c;支持多视图图像采集和3D重建。这种技术通过机械臂搭载的光学系统实现精准的多角度扫描&#xff0c;为医疗团队提供清晰且详细的解剖结构模型。其核心在于结合先进的传感器配置与重…

Qt事件循环机制

受事件循环机制影响&#xff0c;按钮的样式表改变了可能不会立即刷新。 需要使用 update() 或 repaint() 或者调用 QApplication::processEvents() 强制处理所有待处理的事件&#xff0c;从而确保界面更新。 在 Qt 中&#xff0c;事件循环&#xff08;Event Loop&#xff09;是…