亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

jQuery 處理頁面的事件詳解

2024-05-06 16:14:51
字體:
來源:轉載
供稿:網友
這篇文章主要詳細介紹了jQuery 處理頁面的事件的方法及相關資料,需要的朋友可以參考下
 

在之前dom操作中提到了javascript對事件處理的介紹。由于不同瀏覽器處理事件各不相相同,這給開發者帶來了不必要的麻煩,jQuery的方便的解決了這個方面的麻煩。

1.綁定事件監聽

對事件的監聽做了詳細的介紹,看到了iE和DOM標準瀏覽器對待事件監聽的區別,并對多個監聽事件執行順序和方式也不相同。

在jQuery中,通過bind()對事件綁定,相當于IE瀏覽器的attachEvent()和標準DOM的addEventListener()。如下例子:

 

復制代碼代碼如下:

<script type="text/javascript">
            $(function() {
                $("img")
                    .bind("click", function() {
                        $("#show").append("<div>點擊事件1</div>");
                    })
                    .bind("click", function() {
                        $("#show").append("<div>點擊事件2</div>");
                    })
                    .bind("click", function() {
                        $("#show").append("<div>點擊事件3</div>");
                    });
            });
        </script>

 

        <img src="11.jpg">
        <div id="show"></div>

 

以上代碼對img綁定了三個click監聽事件.

bind()通用語法為

bind(eventType,[data],Listener)
其中,eventType為事件的類型,可以是blur/focus/load/resize/scroll/unload/click/dblclick/onmousedown/mouseup/onmouseover/onmouseover/onmouseout/mouseenter/onmouseleave/change/select/submit/onkeydown/keypress/keyup/error

data為可選參數,用來傳遞一些特殊的數據供監聽函數使用。而listener為事件監聽函數,上面的例子中使用匿名函數

對于多個事件類型,如果希望使用同一個監聽函數,可以同事添加在eventType中,事件之間使用空格分離。

 

復制代碼代碼如下:

$(function() {
                $("p").bind("mouseenter mouseleave", function() {
                    $(this).toggleClass("over")
                })
            });

 

另外一些特殊的事件類型可以直接利用事件名稱作為綁定函數,接受參數為監聽函數。例如之前反復使用的

 

復制代碼代碼如下:

$("p").click(function(){
                //添加click事件監聽函數
            })

 

其中,通用語法為

eventTypeName(fn)
可以使用的eventTypeName包括

blur/focus/load/resize/scroll/unload/click/dblclick/onmousedown/onmouseup/mousemove/mouseover/mouseout/change/select/submit/
keydown/keypress/keyup/error等

除了bind()外,jQuery還提供了一個很實用的one()方法來綁定事件。該方法綁定回見出發了一次后就會自動刪除,不再生效。

 

復制代碼代碼如下:

     //首先創建10個<div>塊
            for (var i = 0; i < 10; i++)
                $(document.body).append($("<div>Click<br>Me!</div>"));
            var iCounter = 1;
             //每個都用one添加click事件
            $("div").one("click", function() {
                $(this).css({
                    background: "#8f0000",
                    color: "#FFFFFF"
                }).html("Clicked!<br>" + (iCounter++));
            });

 

例如上例,創建10個div,給每個div綁定一個函數事件,當點擊div塊時,函數執行一次便不再執行。

2.移除事件監聽

jQuery采用unbind()來移除事件,該方法可以接受兩個可選函數,也可不設置任何參數,例如下面的代碼表示移除div標記的所有事件和P標記的所有click事件。

 

復制代碼代碼如下:

$("p").unbind("click");
            $("div").unbind();

 

 如果希望移除某個指定的事件,則必須使用unbind(eventType,listener)方法的第二個參數,例如:

 

復制代碼代碼如下:

var myFunc = function() {
                //監聽函數體
            };
            $("p").bind("click",myFunc);
            $("p").unbind("click",myFunc);

 

例如以下代碼

 

復制代碼代碼如下:

<script type="text/javascript">
            $(function() {
                var fnMyFunc1; //函數變量
                $("img")
                    .bind("click", fnMyFunc1 = function() { //賦給函數變量
                        $("#show").append("<div>點擊事件1</div>");
                    })
                    .bind("click", function() {
                        $("#show").append("<div>點擊事件2</div>");
                    })
                    .bind("click", function() {
                        $("#show").append("<div>點擊事件3</div>");
                    });
                $("input[type=button]").click(function() {
                    $("img").unbind("click", fnMyFunc1); //移除事件監聽myFunc1
                });
            });
        </script>
        
        <img src="11.jpg">
        <input type="button" value="移除事件1">
        <div id="show"></div>

 

例如以上代碼,添加了fnMyFunc1函數bind()綁定時將匿名函數賦值給他,從而作為unbind()函數調用名稱。

3.傳遞事件對象。

介紹了對象的概念,并且分析了事件對象常用的屬性和方法,可以看到事件對象在不同的瀏覽器之間存在很多區別,jQuery中沒時間對象是通過唯一的方法傳遞給事件監聽函數的。

 

復制代碼代碼如下:

<script type="text/javascript">
            $(function() {
                $("p").bind("click", function(e) { //傳遞事件對象e
                    var sPosPage = "(" + e.pageX + "," + e.pageY + ")";
                    var sPosScreen = "(" + e.screenX + "," + e.screenY + ")";
                    $("span").html("<br>Page: " + sPosPage + "<br>Screen: " + sPosScreen);
                });
            });
        </script>
        <p>點擊此處</p>
        <span id=""></span>

 

以上的代碼給p綁定了鼠標click事件監聽函數,并將事件對象作為參數傳遞,從而獲取了鼠標事件觸發點的坐標值。

對于事件的屬性和方法,jQuery最重要的工作就是替開發者解決了兼容性問題,常用的屬性和方法

屬性 說明
altKey 按下alt鍵為ture,否則為false
ctrlKey 按下ctrl鍵為ture,否則為false
shiftKey 按下shift鍵為ture,否則為false
keyCode 對于keyup和keydown事件,返回按鍵的值(即a和A的值是一樣的,都是65)
pageX,pageY 鼠標在客戶端的位置,不包括工具欄,滾動條等
relateTarget 
鼠標事件中,鼠標指針進入或離開元素。

screenX,screenY 鼠標在整個屏幕的位置。
target 引起事件的元素/對象
type 事件的名稱,如click,mouseover等
which 鍵盤事件中為按鍵的unicode值,鼠標按鍵中代表鼠標按鍵(1左鍵 2中鍵 3為右鍵)
stopPropagation() 阻止事件向上冒泡。
preventDefault() 阻止事件默認行為

以上即是本文的全部內容了,講解的非常詳細,希望大家能夠喜歡。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美一区二区三区久久| 亚洲久久久久久久久久| 亚洲国产免费av| 久久久精品视频在线观看| 久久精品久久精品亚洲人| 欧美国产亚洲精品久久久8v| 欧美日韩国产限制| 日韩黄色高清视频| 欧美自拍视频在线| 欧美日韩午夜视频在线观看| 久久精品电影网站| 欧美大成色www永久网站婷| 成人激情av在线| 亚洲第一网中文字幕| 这里只有精品丝袜| 影音先锋欧美精品| 亚洲人成在线观| 伊人一区二区三区久久精品| 成人激情春色网| 国产精品丝袜一区二区三区| 日韩精品视频在线| 欧美精品制服第一页| 亚洲三级黄色在线观看| 日韩经典第一页| 精品国产依人香蕉在线精品| 精品久久久久久久久久久久久久| 亚洲精品suv精品一区二区| 日韩免费黄色av| 欧美最猛性xxxxx免费| 精品国产一区二区三区久久狼5月| 精品一区精品二区| 亚洲日本成人网| 日本高清视频精品| 国产99视频精品免视看7| 亚洲国产成人精品久久久国产成人一区| 一区二区三区视频在线| 一本一道久久a久久精品逆3p| 日韩女优人人人人射在线视频| 久久久噜噜噜久久久| 亚洲视频在线观看| 欧美—级高清免费播放| 九九精品在线观看| 国产精品一二区| 国产精品人人做人人爽| 成人天堂噜噜噜| 91久久久久久国产精品| 日韩av有码在线| 亚洲欧美制服丝袜| 亚洲高清免费观看高清完整版| 国a精品视频大全| 欧美特黄级在线| 欧美中文在线观看| 亚洲激情在线视频| 日本精品久久久| 欧美激情视频一区二区三区不卡| 国产精品久久久久av| 亚洲免费成人av电影| www.欧美三级电影.com| 欧美成人激情视频免费观看| 69久久夜色精品国产69| 久久综合伊人77777蜜臀| 国语自产精品视频在线看抢先版图片| 日韩av网站导航| 中文字幕视频在线免费欧美日韩综合在线看| 久久国产精品久久精品| 久久精品亚洲热| 国产美女久久精品香蕉69| 一区二区三区视频免费| 亚洲一区二区三区视频| 不卡av在线网站| 国产一区玩具在线观看| 欧美综合一区第一页| www.xxxx欧美| 97久久精品人人澡人人爽缅北| 国产一区视频在线播放| 中文字幕亚洲一区二区三区五十路| 日韩免费在线观看视频| 国产精品91免费在线| 成人黄色在线播放| 久久噜噜噜精品国产亚洲综合| 精品久久香蕉国产线看观看gif| 欧美与欧洲交xxxx免费观看| 日韩av在线免费播放| 亚洲国内精品在线| 久久久久久综合网天天| 国产成人福利视频| 亚洲大胆美女视频| 国产在线观看精品| 亚洲字幕一区二区| 亚洲精品永久免费精品| 欧美激情一区二区久久久| 国产精彩精品视频| 欧美日韩国产成人高清视频| 成人综合网网址| 亚洲精品国产免费| 精品一区二区三区四区在线| 久久久久久久久久婷婷| 成人黄色影片在线| 久久久中精品2020中文| 一区二区三区亚洲| 91久久国产婷婷一区二区| 国产精品视频一区国模私拍| 色av吧综合网| 国产日本欧美在线观看| 亚洲视频视频在线| 久久久久久久成人| 精品中文字幕视频| 国产午夜精品免费一区二区三区| 精品一区二区三区四区在线| 日本老师69xxx| 欧美日韩成人在线观看| 欧美激情免费在线| 中文字幕自拍vr一区二区三区| 国产精品老牛影院在线观看| 久久亚洲精品成人| 日韩在线观看免费网站| 亚洲欧美日韩精品| 国产欧美一区二区| 九九热在线精品视频| 欧美激情视频在线免费观看 欧美视频免费一| 高清日韩电视剧大全免费播放在线观看| 欧洲成人免费aa| 国产视频在线一区二区| 亚洲香蕉成人av网站在线观看| 亚洲成人精品久久久| 久久免费高清视频| 日韩激情视频在线| 91a在线视频| 亚洲大胆人体在线| 青青草99啪国产免费| 国产91精品久久久久久| 97色伦亚洲国产| 欧美在线视频网| 久久九九精品99国产精品| 91精品美女在线| 精品无人区乱码1区2区3区在线| 日av在线播放中文不卡| 欧美成人激情图片网| 一区二区三区回区在观看免费视频| 欧美人在线观看| 欧美性精品220| 久久精品亚洲热| 国产精品福利在线观看| 欧美精品激情在线观看| 久久久免费av| 亚洲福利在线视频| 国产日产欧美a一级在线| 日韩精品视频免费专区在线播放| 欧美激情成人在线视频| 在线观看国产精品91| 国产精品精品一区二区三区午夜版| 97在线精品国自产拍中文| 欧美一区亚洲一区| 国产精品日韩欧美| 日韩成人中文字幕在线观看| 亚洲韩国欧洲国产日产av| 91精品国产91| 久热在线中文字幕色999舞| 91福利视频在线观看| 国产日韩精品在线观看| 亚洲精品一区二三区不卡| 永久免费精品影视网站| 亚洲最大成人网色| 久久综合久久八八|