JavaScript 中,自定義事件允許開發人員創建並觸發特定應用事件,讓程式碼做出反應:使用 new CustomEvent() 構造函數創建自定義事件。使用 dispatchEvent() 方法觸發自定義事件。使用 addEventListener() 方法監聽自定義事件,獲取事件名稱、事件監聽器和捕獲階段。自定義事件物件具有 type、detail、bubbles 和 cancelable 屬性。自定義事件可用于元件間傳遞訊息、處理使用者互動和監控狀態變化。

JavaScript 自定義事件
JavaScript 中的自定義事件允許開發人員創建和觸發應用程式中的特定事件,讓程式碼在這些事件發生時做出反應。
如何創建自定義事件
要創建自定義事件,請使用 new CustomEvent() 構造函數。它接受兩個參數:
-
eventName: 事件名稱(例如 "myCustomEvent") -
eventInitDict(可選):包含事件屬性的字典物件
範例:
const myCustomEvent = new CustomEvent('myCustomEvent');如何觸發自定義事件
要觸發自定義事件,請使用 dispatchEvent() 方法。它接受一個自定義事件物件作為參數:
範例:
document.dispatchEvent(myCustomEvent);
添加事件監聽器
要監聽自定義事件,請使用 addEventListener() 方法。它接受三個參數:
-
eventName: 要監聽的事件名稱 -
eventListener: 在事件發生時要執行的函數 -
useCapture(可選):指定是否在捕獲階段或泡沫階段調用函數
範例:
document.addEventListener('myCustomEvent', (event) => {
console.log('自定義事件觸發!');
});事件屬性
自定義事件物件具有以下屬性:
-
type: 事件名稱 -
detail: 與事件相關的任何附加資料 -
bubbles: 指定事件是否在 DOM 樹中冒泡 -
cancelable: 指定事件是否可以取消
自定義事件的用途
自定義事件可用于各種用途,包括:
- 在元件間傳遞訊息
- 處理使用者互動(例如點擊、滑鼠移入)
- 監控狀態變化(例如頁面載入、視窗大小調整)










