使用jQuery中trigger()方法自動觸發事件

來源:互聯網
上載者:User

標籤:瀏覽器   回呼函數   bsp   details   執行   test   使用者   message   handle   

一、常用事件

在頁面載入完成時  自動觸發input的點擊事件,在移動端可以實現自動彈出IME,獲得焦點

$("input").trigger("click").focus();

還有一種簡寫方式:

$("input").click();

還有其它事件就不一一列出了。

 

二、自訂事件

$("#btn").on("myClick",function(){   alert("自訂事件");});$("#btn").trigger("myClick");

 

三、傳遞參數

trigger(tpye[,datea])方法有兩個參數,第一個參數是要觸發的事件類型,第二個單數是要傳遞給事件處理函數的附加資料,以數組形式傳遞。通常可以通過傳遞一個參數給回呼函數來區別這次事件是代碼觸發的還是使用者觸發的。

$("#btn").bind("myClick", function (event, message1, message2) { //擷取資料    $("#test").append("p" + message1 + message2 + "</p>");});$("#btn").trigger("myClick",["我的自訂","事件"]); //傳遞兩個資料

$(“#btn”).trigger(“myClick”,["我的自訂","事件"]); //傳遞兩個資料

 

四、執行預設操作

triger()方法觸發事件後,會執行瀏覽器預設操作。例如:

$("input").trigger("focus");

以上代碼不僅會觸發為input元素繫結的focus事件,也會使input元素本身得到焦點(瀏覽器預設操作)。

如果只想觸發綁定的focus事件,而不想執行瀏覽器預設操作,可以使用jQuery中另一個類似的方法-triggerHandler()方法。

$("input").triggerHandler("focus");

該方法會觸發input元素上綁定的特定事件,同時取消瀏覽器對此事件的預設操作,即文字框指觸發綁定的focus事件,不會得到焦點。

 

教程參考地址:http://blog.csdn.net/lijunling2008live/article/details/7457396

使用jQuery中trigger()方法自動觸發事件

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.