jquery trigger函數執行兩次的解決方案,jquerytrigger

來源:互聯網
上載者:User

jquery trigger函數執行兩次的解決方案,jquerytrigger

本文執行個體講述了jquery trigger函數執行兩次的解決方案。分享給大家供大家參考,具體如下:

一、問題如下:

有如下代碼:

<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title></title><style type="text/css">*{margin:0;padding:0;}    body { font-size: 13px; line-height: 130%; padding: 60px; }p {width:200px;background:#888;color:white;height:16px;}</style><script src="jquery-1.6.4.js" type="text/javascript"></script><script type="text/javascript">$(function(){  $('#old').bind("click", function(){        $("input").trigger("focus");    });    $('#new').bind("click", function(){      $("input").triggerHandler("focus");    });    $("input").focus(function(){  $("body").append("<p>focus.</p>");})});</script></head><body><button id="old">trigger</button><button id="new">triggerHandler</button><input /></body></html>

這裡的函數:

$('#old').bind("click", function(){$("input").trigger("focus");});

在Firefox只觸發一次,即輸出一個focus;

但是在ie觸發了兩次,即同時輸出了兩個focus;

二、解決方案:

首先分析一下trigger和triggerHandler。使用triggerHandler不會觸發瀏覽器的預設事件,不會產生事件冒泡(其他區別看jQuery文檔)。關於這個bug的 ticket。關於這個問題的 commit。jQuery自己實現了一個event對象用於解決瀏覽器間的差異問題。可是由於有mouseenter/mouseleave等非標準事件的存在,jQuery引入了special事件的子系統,讓原生事件回到類比事件的事件列隊中,可是這個系統並不能解決所有問題,當使用trigger.focus時,IE下會錯誤地執行兩次回調。

triggerHandler是對trigger產生這種問題的解決方案。但是使用triggerHandler時你會發現input是沒有游標focus效果的。

初步解決方案:

除了用triggerHandler另一個方法是在focus綁定事件中加上:

event.preventDefault()

可是你發現這不符合我們的期望呀,因為focus事件回調執行了,但是連個focus效果都沒有。

最終解決方案:

既然是jQuery封裝的關係,那我們用原生的事件就可以了。看示範,左邊是用原生事件觸發的,右邊用triggerHandler。

$('input')[0].focus();

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.