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.pswp.cn/bicheng/81353.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/81353.shtml
英文地址,請注明出處:http://en.pswp.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;是…