許多JavaScript任務需要僅觸發一次的事件。 想一想在第一次點擊時加載視頻的縮略圖,或通過Ajax獲取其他內容的“更多”按鈕。 反复觸發同一事件處理程序效率低下,可能導致意外行為(例如,冗餘數據加載)。 幸運的是,在JavaScript中創建一次性事件處理程序很簡單。該過程通常涉及:
- >附加處理程序:>將事件處理程序(函數)分配給事件(例如單擊)。
- 處理程序執行:事件發生時,處理程序運行。 然後將處理程序拆卸
- 處理程序,然後將處理程序分離,以防止在隨後的事件中進一步執行。
使用jQuery的方法one()
如果您使用的是jQuery,最簡單的解決方案是one()
>方法:
$("#myelement").one("click", function() { alert("This message appears only once!"); });
>就像其他jQuery事件方法一樣。 有關詳細的文檔,請參見jQuery API:https://www.php.cn/link/55e71b444408e917b917bbb0bbbb0df7d0b81af4。
>自我驅動的處理程序(plain javaScript)>
在普通的JavaScript中,任何處理程序功能都可以刪除自身:>在第一次調用後,將其刪除處理程序。 無論處理程序的姓名或事件類型如何,都可以使用。請注意,在嚴格的模式下不支持
document.getElementById("myelement").addEventListener("click", handler); function handler(e) { e.target.removeEventListener(e.type, arguments.callee); alert("This message appears only once!"); }; 在現代JavaScript中,您可以使用命名函數並直接引用它。 對於較舊的IE版本,您需要
和“ on”前綴(例如,“ onclick”)。 e.target.removeEventListener(e.type, arguments.callee);
>
arguments.callee
detachEvent
>可重複使用的一次性事件函數
避免反复編寫刪除代碼,創建一個可重複使用的函數:
function oneTimeEvent(node, type, callback) { node.addEventListener(type, function(e) { e.target.removeEventListener(e.type, arguments.callee); callback(e); }); }
>現代JavaScript的
選項oneTimeEvent(document.getElementById("myelement"), "click", function(e) { alert("This message appears only once!"); });
最現代,最清潔的方法在once
>中使用選項:
once: true
這是大多數現代瀏覽器支持的,避免了手動刪除的需求。
addEventListener
>並非總是必要的,但是了解創建一次性事件處理程序的這些技術為您的JavaScript項目提供了寶貴的靈活性和效率。 選擇最適合您項目依賴性和編碼樣式的方法。
以上是如何在JavaScript中創建一次性事件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

10款趣味橫生的jQuery遊戲插件,讓您的網站更具吸引力,提升用戶粘性!雖然Flash仍然是開發休閒網頁遊戲的最佳軟件,但jQuery也能創造出令人驚喜的效果,雖然無法與純動作Flash遊戲媲美,但在某些情況下,您也能在瀏覽器中獲得意想不到的樂趣。 jQuery井字棋遊戲 遊戲編程的“Hello world”,現在有了jQuery版本。 源碼 jQuery瘋狂填詞遊戲 這是一個填空遊戲,由於不知道單詞的上下文,可能會產生一些古怪的結果。 源碼 jQuery掃雷遊戲

本教程演示瞭如何使用jQuery創建迷人的視差背景效果。 我們將構建一個帶有分層圖像的標題橫幅,從而創造出令人驚嘆的視覺深度。 更新的插件可與JQuery 1.6.4及更高版本一起使用。 下載

Matter.js是一個用JavaScript編寫的2D剛體物理引擎。此庫可以幫助您輕鬆地在瀏覽器中模擬2D物理。它提供了許多功能,例如創建剛體並為其分配質量、面積或密度等物理屬性的能力。您還可以模擬不同類型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流瀏覽器。此外,它也適用於移動設備,因為它可以檢測觸摸並具有響應能力。所有這些功能都使其值得您投入時間學習如何使用該引擎,因為這樣您就可以輕鬆創建基於物理的2D遊戲或模擬。在本教程中,我將介紹此庫的基礎知識,包括其安裝和用法,並提供一

本文演示瞭如何使用jQuery和ajax自動每5秒自動刷新DIV的內容。 該示例從RSS提要中獲取並顯示了最新的博客文章以及最後的刷新時間戳。 加載圖像是選擇

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3漢化版
中文版,非常好用

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。