关于a标签不能调用js方法的小细节,你注意到了么?
生活随笔
收集整理的這篇文章主要介紹了
关于a标签不能调用js方法的小细节,你注意到了么?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在我們做后臺刪除的時候,當點擊刪除標簽時,你希望彈出一個友好的提示框!比如這樣:
那代碼應該怎樣寫呢?向下面這樣?
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><script>window.οnlοad=function () {function confirmdelete(id) {return window.confirm("你確定要刪除嗎?");}}</script> </head> <body></body> <?phpecho "<a οnclick='confirmdelete(2)'>刪除</a>"; ?>你會發現會發生這樣一個錯誤:
該函數沒有被使用?不應該啊,我在php里面不是已經調用了么?
注意:
想必寫過前端的人都知道這個方法是在頁面全部加載完成之后執行,那么問題就來了,php的執行順序是先于js的,所以當執行php的時候,發現a標簽里面的方法并不存在,因為此刻js還沒有被執行,所以就導致了php a標簽調用js的時候沒有反應這種情況了。
那么代碼變成這樣呢?
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><script>function confirmdelete(id) {return window.confirm("你確定要刪除嗎?");}</script> </head> <body></body> <?phpecho "<a οnclick='return confirmdelete(2)'>刪除</a>"; ?>結果是成功執行!有人說不對啊,你不是說php的執行順序要先于js么,這個和上面沒什么區別啊。
那么此刻就要注意了,有了window.onload這個方法約束后,該js是最后執行,那么 當去掉這個約束,你會發現這個函數
?
只是一個聲明,在js當中,對于只是聲明的函數,它會最先編譯,所以這時候當執行到php的a標簽時,因為它要調用的函數已經預先編譯好了,所以就能夠調用。
?
轉載于:https://www.cnblogs.com/hzStudy/p/7224086.html
總結
以上是生活随笔為你收集整理的关于a标签不能调用js方法的小细节,你注意到了么?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Go语言内存对齐详解
- 下一篇: 怎么删除映射网络里的计算机,W7怎么样删