Javascript:意外調用onclick 處理程序
嘗試建立類似錨標記但執行自訂函數的連結時,onclick頁面載入後立即呼叫函數,使後續點擊無效。
說明:
在提供的程式碼片段中:
<code class="javascript">var sendNode = document.createElement('a'); sendNode.setAttribute('onclick', secondFunction());</code>
行setAttribute('oncunc', secondaryFlicktion()) 不正確。它立即執行 SecondFunction 函數並將其傳回值(通常未定義)指派給 onclick 屬性。這會導致立即呼叫 secondaryFunction。
解決方案:
要正確將secondaryFunction 指定為事件處理程序,正確的語法是:
<code class="javascript">var sendNode = document.createElement('a'); sendNode.setAttribute('onclick', secondFunction);</code>
這將建立一個事件偵聽器,在呼叫第二個函數之前等待元素上的單擊事件。
以上是為什麼 onclick 處理程序在頁面載入時觸發,而不是在點擊連結時觸發?的詳細內容。更多資訊請關注PHP中文網其他相關文章!