首頁 web前端 js教程 給事件響應函數傳參數的四種方式小結_javascript技巧

給事件響應函數傳參數的四種方式小結_javascript技巧

May 16, 2016 pm 05:10 PM
函數參數

如何傳參數給事件handler?剛接觸Javascript的時候,由於對閉包理解不深刻,常常糾結於此問題。

在討論群組也常常碰到這樣的問題,如下

複製程式碼 程式碼如下:


程式碼如下:



程式碼如下:



程式碼如下:





   
    如何給事件handler傳參數?


 Click me
 
  // 預設事件對象將作為handler的第一個參數傳入,
  // 這時點選連結第一個彈出的是事件對象,第二個是undefined。   E.on(document.getElementById('aa'),'click',handler);

 



複製程式碼


程式碼如下:


function handler(arg1,arg2){
 alert(arg1);
 alert(arg2);
}
E.on(document.getElementById('aa'ById('aa'ById('aa'ById('aa'ById('aa'ById('aa'ById('aa'),' click',function(){  handler(arg1,arg2); });方案二,保留事件物件為第一個參數 


複製程式碼


程式碼如下:


function handler(e,arg1,arg2){
  alert(arg1);
 alert(arg2);
}
E.on(document.getElementById('aa'),'click',function(e){ handler(e ,arg1,arg2);});方案三,給Function.prototype加上getCallback,不保留事件物件













複製程式碼


程式碼如下:


Function.prototype.getCallback = function(){
 var _this = this, args = function(){
 var _this = this, args = function(){
 var _this = this, args = arguments; (e) {
        return _this.apply(this || window, args);    };}E.on(document.getElementById('lick),ler' .getCallback(v1,v2));方案四,加入Function.prototypegetCallback,保留事件物件作為第一個參數傳入 複製程式碼 程式碼如下:Function.prototype.getCallback = function(){ var _this = this, args = []; for(var i=0,l=arguments.length;i  args[i 1] = arguments[i]; } return function(e) {  args[0] = e;        return _this.apply(this || window, args);    };}}.on(docum 'click',handler.getCallback(v1,v2));
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

C++ 函式參數傳遞方式與執行緒安全的關係 C++ 函式參數傳遞方式與執行緒安全的關係 Apr 12, 2024 pm 12:09 PM

函數參數傳遞方式與線程安全:值傳遞:建立參數副本,不影響原始值,通常線程安全。引用傳遞:傳遞位址,允許修改原始值,通常不線程安全。指針傳遞:傳遞指向位址的指針,類似引用傳遞,通常不線程安全。在多執行緒程式中,應慎用引用和指標傳遞,並採取措施防止資料競爭。

C++ 函式參數詳解:不定參數傳遞的實作方式與優缺點 C++ 函式參數詳解:不定參數傳遞的實作方式與優缺點 Apr 28, 2024 am 09:48 AM

C++不定參數傳遞:透過...運算子實現,可接受任意數量的附加參數,優點包括靈活性、可擴展性和簡化程式碼,缺點包括效能開銷、除錯困難和類型安全。常見實戰案例包括printf()和std::cout,它們使用va_list處理可變數量的參數。

C++編譯錯誤:重複定義函式參數,該怎麼解決? C++編譯錯誤:重複定義函式參數,該怎麼解決? Aug 22, 2023 pm 12:33 PM

C++作為一種高效率的程式語言,因其可靠性被廣泛應用於各種各樣的領域。但是,在編寫程式碼的過程中,常常會遇到一些編譯錯誤,其中重複定義函數參數就是其中之一。本文將詳細介紹重複定義函數參數的原因和解決方案。什麼是重複定義函數參數?在C++程式設計中,函數參數是指在函式定義和宣告中出現的變數或表達式,用於接受函式呼叫時傳遞的實參。在定義函數的參數清單時,每個參數都必須使用

C++ 函式參數詳解:傳出機制的本質與注意事項 C++ 函式參數詳解:傳出機制的本質與注意事項 Apr 27, 2024 pm 12:00 PM

C++函式參數傳遞方式有兩種:傳值呼叫(不影響實參)和傳引用呼叫(影響實參)。傳出參數透過傳引用或指標實現,函數可以透過修改參數引用或指標指向的變數來傳遞值給呼叫方。使用時需要注意:傳出參數必須明確聲明,只能對應一個實參,不能指向函數內局部變量,傳指針呼叫需謹慎避免野指​​針。

數組可以當函數參數嗎? 數組可以當函數參數嗎? Jun 04, 2024 pm 04:30 PM

是的,在許多程式語言中,數組可以作為函數參數,函數將對其中儲存的資料執行操作。例如C++中的printArray函數可以列印數組中的元素,而Python中的printArray函數可以遍歷數組並列印其元素。這些函數對陣列所做的修改也會反映在呼叫函數中的原始數組中。

PHP 函數參數型別有哪些? PHP 函數參數型別有哪些? Apr 10, 2024 pm 04:21 PM

PHP函數參數類型包括標量類型(整數、浮點數、字串、布林值、空值)、複合型別(陣列、物件)和特殊型別(回呼函數、可變參數)。函數可自動轉換不同類型參數,但也可透過類型聲明強制特定類型,以防止意外轉換並確保參數正確性。

如何選擇 C++ 函數參數的傳遞方式? 如何選擇 C++ 函數參數的傳遞方式? Apr 12, 2024 am 11:45 AM

在C++中選擇函數參數傳遞方式時,有四種選擇:按值傳遞、按引用傳遞、按指標傳遞和按const引用傳遞。按值傳遞建立參數值的副本,不會影響原始參數;按引用傳遞參數值的引用,可以修改原始參數;按指針傳遞參數值的指針,允許透過指針修改原始參數值;按const引用傳遞參數值的const引用,只能存取參數值,不能修改。

C++ 函式參數傳遞方式與模板元程式設計的關係 C++ 函式參數傳遞方式與模板元程式設計的關係 Apr 12, 2024 pm 01:21 PM

函數參數傳遞方式與模板元程式設計的關係:值傳遞:複製參數值,函數無法修改原始變數。引用傳遞:傳遞對參數的引用,函數可修改原始變數。指針傳遞:傳遞指向參數的指針,函數可透過解引用指針修改原始變數。模板元編程可以根據參數類型產生不同的程式碼,透過指定參數傳遞方式。

See all articles