<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        js事件(Event)知識整理_javascript技巧

        來源:懂視網 責編:小采 時間:2020-11-27 21:05:14
        文檔

        js事件(Event)知識整理_javascript技巧

        js事件(Event)知識整理_javascript技巧:鼠標事件 鼠標移動到目標元素上的那一刻,首先觸發mouseover 之后如果光標繼續在元素上移動,則不斷觸發mousemove 如果按下鼠標上的設備(左鍵,右鍵,滾輪……),則觸發mousedown 當設備彈起的時候觸發mouseup 目標元素的滾動條發生移動時(滾動滾輪/拖動滾動
        推薦度:
        導讀js事件(Event)知識整理_javascript技巧:鼠標事件 鼠標移動到目標元素上的那一刻,首先觸發mouseover 之后如果光標繼續在元素上移動,則不斷觸發mousemove 如果按下鼠標上的設備(左鍵,右鍵,滾輪……),則觸發mousedown 當設備彈起的時候觸發mouseup 目標元素的滾動條發生移動時(滾動滾輪/拖動滾動

        鼠標事件

        鼠標移動到目標元素上的那一刻,首先觸發mouseover
        之后如果光標繼續在元素上移動,則不斷觸發mousemove
        如果按下鼠標上的設備(左鍵,右鍵,滾輪……),則觸發mousedown
        當設備彈起的時候觸發mouseup
        目標元素的滾動條發生移動時(滾動滾輪/拖動滾動條。)觸發scroll
        滾動滾輪觸發mousewheel,這個要區別于scroll
        鼠標移出元素的那一刻,觸發mouseout

        事件注冊

        平常我們綁定事件的時候用dom.onxxxx=function(){}的形式
        這種方式是給元素的onxxxx屬性賦值,只能綁定有一個處理句柄。
        但很多時候我們需要綁定多個處理句柄到一個事件上,而且還可能要動態的增刪某個處理句柄
        下面的事件注冊方式就能解決這個需求。

        先介紹一下四個方法
        代碼如下:
        //IE以外
        target.addEventListener(type,listener,useCapture)
        target.removeEventListener(type,listener,useCapture);
        target :文檔節點、document、window 或 XMLHttpRequest。
        type :字符串,事件名稱,不含“on”,比如“click”、“mouseover”、“keydown”等。
        listener :實現了 EventListener 接口或者是 JavaScript 中的函數。
        useCapture :是否使用捕捉,一般用 false。
        //IE
        target.attachEvent(type, listener);
        target.detachEvent(type, listener);
        target :文檔節點、document、window 或 XMLHttpRequest。
        type :字符串,事件名稱,含“on”,比如“onclick”、“onmouseover”、“onkeydown”等。
        listener :實現了 EventListener 接口或者是 JavaScript 中的函數。
        兩者使用的原理:可對執行的優先級不一樣,實例講解如下:
        ele.attachEvent("onclick",method1);
        ele.attachEvent("onclick",method2);
        ele.attachEvent("onclick",method3);
        執行順序為method3->method2->method1
        ele.addEventListener("click",method1,false);
        ele.addEventListener("click",method2,false);
        ele.addEventListener("click",method3,false);
        執行順序為method1->method2->method3
        兼容后的方法
        var func = function(){};
        //例:addEvent(window,"load",func)
        function addEvent(elem, type, fn) {
        if (elem.attachEvent) {
        elem.attachEvent('on' + type, fn);
        return;
        }
        if (elem.addEventListener) {
        elem.addEventListener(type, fn, false);
        }
        }
        //例:removeEvent(window,"load",func)
        function removeEvent(elem, type, fn) {
        if (elem.detachEvent) {
        elem.detachEvent('on' + type, fn);
        return;
        }
        if (elem.removeEventListener) {
        elem.removeEventListener(type, fn, false);
        }
        }

        獲取事件對象和事件源(觸發事件的元素)
        代碼如下:
        function eventHandler(e){
        //獲取事件對象
        e = e || window.event;//IE和Chrome下是window.event FF下是e
        //獲取事件源
        var target = e.target || e.srcElement;//IE和Chrome下是srcElement FF下是target
        }

        取消事件默認行為(例如點擊一個后不跳轉頁面而是執行一個函數)
        代碼如下:
        function eventHandler(e) {
        e = e || window.event;
        // 防止默認行為
        if (e.preventDefault) {
        e.preventDefault();//IE以外
        } else {
        e.returnValue = false;//IE
        //注意:這個地方是無法用return false代替的
        //return false只能取消元素
        }
        }

        阻止事件冒泡
        代碼如下:
        function myParagraphEventHandler(e) {
        e = e || window.event;
        if (e.stopPropagation) {
        e.stopPropagation();//IE以外
        } else {
        e.cancelBubble = true;//IE
        }
        }

        事件委托

        例如,你有一個很多行的大表格,在每個上綁定點擊事件是個非常危險的想法,因為性能是個大問題。流行的做法是使用事件委托。

        事件委托描述的是將事件綁定在容器元素上,然后通過判斷點擊的target子元素的類型來觸發相應的事件。
        事件委托依賴于事件冒泡,如果事件冒泡到table之前被禁用的話,那以下代碼就無法工作了。

        代碼如下:
        myTable.onclick = function () {
        e = e || window.event;
        var targetNode = e.target || e.srcElement;
        // 測試如果點擊的是TR就觸發
        if (targetNode.nodeName.toLowerCase() === 'tr') {
        alert('You clicked a table row!');
        }
        }

        事件(Event)知識整理(二)

        事件流

        DOM同時支持兩種事件模型:捕獲型事件和冒泡型事件
        并且每當某一事件發生時,都會經過捕獲階段->處理階段->冒泡階段(有些瀏覽器不支持捕獲)

        捕獲階段是由上層元素到下層元素的順序依次。而冒泡階段則正相反。

        如下圖

        當事件觸發時body會先得到有事件發生的信息,然后依次往下傳遞,直到到達最詳細的元素。這就是事件捕獲階段。
        還記得事件注冊方法ele.addEventListener(type,handler,flag)吧,Flag是一個Boolean值,true表示事件捕捉階段執行,false表示事件冒泡階段執行。
        接著就是事件冒泡階段。從下往上 依次執行事件處理函數(當然前提是當前元素為該事件注冊了事件句柄)。
        在這個過程中,可以阻止事件的冒泡,即停止向上的傳遞。
        阻止冒泡有時是很有必要的,例如

        代碼如下:



        本意是如果點擊div中按鈕以外的位置時執行funcA,點擊button時執行funcB。但是實際點擊button時就會先后執行funcB,funcA。
        而如果在button的事件句柄中阻止冒泡的話,div就不會執行事件句柄了。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        js事件(Event)知識整理_javascript技巧

        js事件(Event)知識整理_javascript技巧:鼠標事件 鼠標移動到目標元素上的那一刻,首先觸發mouseover 之后如果光標繼續在元素上移動,則不斷觸發mousemove 如果按下鼠標上的設備(左鍵,右鍵,滾輪……),則觸發mousedown 當設備彈起的時候觸發mouseup 目標元素的滾動條發生移動時(滾動滾輪/拖動滾動
        推薦度:
        標簽: 整理 知識 事件
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 91情侣在线精品国产免费| 久久国产精品免费视频| 午夜无遮挡羞羞漫画免费| 亚洲人成毛片线播放| 免费看污成人午夜网站| 亚洲国产成a人v在线| 无限动漫网在线观看免费 | 免费无码精品黄AV电影| 亚洲日产2021三区在线 | 久久精品国产亚洲av品善| 日本高清免费中文字幕不卡| 亚洲AV成人片无码网站| 国产免费久久精品| 乱淫片免费影院观看| 亚洲国产精品无码专区在线观看 | 国产成人精品日本亚洲专| 啦啦啦中文在线观看电视剧免费版 | 日本免费A级毛一片| 久久亚洲中文字幕精品有坂深雪| 国产黄色免费网站| 亚洲男同gay片| 亚洲免费一区二区| 91视频免费网址| 亚洲国产区男人本色| 亚洲精品国产V片在线观看| A级毛片高清免费视频在线播放| 亚洲成电影在线观看青青| 免费看AV毛片一区二区三区| 久香草视频在线观看免费| 亚洲第一页中文字幕| 四虎永久成人免费| 免费国产99久久久香蕉| 亚洲乱亚洲乱妇无码| 亚洲精品国精品久久99热一| 99久久免费国产香蕉麻豆 | 亚洲欧美日韩中文二区| 亚洲五月午夜免费在线视频| 韩国日本好看电影免费看| 一级毛片**免费看试看20分钟 | 久久黄色免费网站| 亚洲Av永久无码精品一区二区|