JavaScript 注册事件代码_javascript技巧
首先是最常规的方法:
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR></script>
当某一天,我们知道JavaScript要跟HTML结构实现分离后,就会改了一种写法:
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR>window.onload = function(){ <BR>document.getElementById("para").onclick = test; <BR>} <BR></script>
当我们工作越来越久后,有时候我们需要对某个元素绑定多个相同的事件类型:
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR>function pig(){ <BR>alert("pig"); <BR>} <BR>window.onload = function(){ <BR>document.getElementById("para").onclick = test; <BR>document.getElementById("para").onclick = pig; <BR>} <BR></script>
如果按照上面的写法,我们只能输出第二个函数。
这时候我们需要用到attachEvent方法:
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR>function pig(){ <BR>alert("pig"); <BR>} <BR>window.onload = function(){ <BR>document.getElementById("para").attachEvent("onclick",test); <BR>document.getElementById("para").attachEvent("onclick",pig); <BR>} <BR></script>
在一段时间内,你并没发现这段代码有任何错误。
某一天,一个名叫firefox的浏览器 闯入你的视野,当我们把这段代码放到firefox中执行后,
发现并不能正常运行。 问题就这样,越来越多,然而作为一名JS程序员,这些都是必须面对的。
为了解决这段代码的平台兼容性问题,我翻翻手册,知道了firefox跟ie的区别:
firefox中注册事件使用:addEventListener方法,同时为了兼容ie,我们必须用到if ... else...
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR>function pig(){ <BR>alert("pig"); <BR>} <BR>window.onload = function(){ <BR>var element = document.getElementById("para"); <BR>if(element.addEventListener){ // firefox , w3c <BR>element.addEventListener("click",test,false); <BR>element.addEventListener("click",pig,false); <BR>} else { // ie <BR>element.attachEvent("onclick",test); <BR>element.attachEvent("onclick",pig); <BR>} <BR>} <BR></script>
此时,代码就可以在多个平台上工作了。
但随着水平的进步,你不满足每次都去判断,你想把这个判断封装起来,以后可以直接调用:
程序代码
复制代码 代码如下:
test
<script> <BR>function test(){ <BR>alert("test"); <BR>} <BR>function pig(){ <BR>alert("pig"); <BR>} <BR>function addListener(element,e,fn){ <BR>if(element.addEventListener){ <BR>element.addEventListener(e,fn,false); <BR>} else { <BR>element.attachEvent("on" + e,fn); <BR>} <BR>} <BR>window.onload = function(){ <BR>var element = document.getElementById("para"); <BR>addListener(element,"click",test); <BR>addListener(element,"click",pig); <BR>} <BR></script>
至此,作为一个程序员的工作就完了。
中间我们从一个最传统,最基本的写法 , 然后实现Js和HTML的分离,然后又实现对同一个元素注册多个事件,期间,我们发现注册事件的兼容性问题。最后我们对注册事件的方法进行封装,方便以后使用。
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前
By 尊渡假赌尊渡假赌尊渡假赌
刺客信條陰影:貝殼謎語解決方案
2 週前
By DDD
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前
By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

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

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

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

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

本文說明瞭如何使用源地圖通過將其映射回原始代碼來調試JAVASCRIPT。它討論了啟用源地圖,設置斷點以及使用Chrome DevTools和WebPack之類的工具。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...
