搜尋

首頁  >  問答  >  主體

javascript - 請教 jquery 中 trigger('click') 和 click() 的差異與優劣。

$('#btn').trigger('click');
$('#btn').click();

求教這兩種 click 事件的觸發方式選擇哪一個比較優?

为情所困为情所困2713 天前917

全部回覆(3)我來回復

  • phpcn_u1582

    phpcn_u15822017-06-26 11:00:52

    jquery2的源碼

    jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " +
        "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +
        "change select submit keydown keypress keyup error contextmenu").split(" "), function( i, name ) {
    
        // Handle event binding
        jQuery.fn[ name ] = function( data, fn ) {
            return arguments.length > 0 ?
                this.on( name, null, data, fn ) :
                this.trigger( name );
        };
    });

    看起來,$物件的click執行事件實作也是呼叫trigger…所以trigger比較優? = =||跟 @MockingBird 的想法不同- -

    回覆
    0
  • 女神的闺蜜爱上我

    女神的闺蜜爱上我2017-06-26 11:00:52

    trigger() 主要用來觸發自訂事件

    $( "#foo" ).on( "custom", function( event, param1, param2 ) {
      alert( param1 + "\n" + param2 );
    });
    $( "#foo").trigger( "custom", [ "Custom", "Event" ] );

    @Dont 貼出了 jquery 原始碼, 其實 .click() 也是直接呼叫 .trigger() 方法,所以效能上應該是一樣的。

    回覆
    0
  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-26 11:00:52

    就像jQuery.post()和jQuery.ajax()哪個比較優? ?

    明明可以猜post肯定是呼叫了ajax, 那就用ajax? 就因為少了一次函數呼叫?然後多打好些字?浪費時間?

    沒有什麼優不優的,你要想想別的方面, 簡潔,易懂也很重要。

    回覆
    0
  • 取消回覆