JQuery.triggerでパラメーターを渡す


82

JQueryトリガーを使用していますが、状況に応じてパラメーターを渡すための正しい構文がわかりません。これが私が電話をかけているところです:

$('#'+controlName).trigger(event);

これが私がイベントバインディングを行っているところです:

$(window).on('onPartialRendered', onPartialRendered);

そして、これが私のイベントハンドラーです:

var onPartialRendered = function () {

    .....
};

パラメータを渡そうとするまで、すべて正常に動作します。私の例のようにそれを行う正しい方法は何でしょうか?


はい、トリガー(event、['Param1'、 'Param2'])の構文を使用してパラメーターを渡そうとしましたが、成功しませんでした
user517406 2013年

あなたは、onPartialRenderedその署名のいずれかのパラメータを持っていません。する必要がありますonPartialRendered = function(e, p1, p2)
ロケット危険物2013年

@ user517406機能しなかったパラメータをどのように渡そうとしましたか?
epascarello 2013年

@ user517406 jsfiddle.netにコードを投稿して、遊んでみてください。
Edper 2013年

回答:


151

最初のパラメーターは常にイベント名を含む文字列であり、次のパラメーターは追加データです。

.trigger('foo', [1, 2]);

.on('foo', function(event, one, two) { ... });

ロケット危険物に感謝します

例:

var controller = {
  listen: function (event, json, string) {}
};

$('body').trigger('this_works', [{data: [1, 2, 3]}, 'something']);

$('body').on('this_works', function (event, json, string) {
  controller.listen(event, json, string);
});

リモートパーシャル:

このように使用しないでください。ネットワークのこの問題に関する多くの記事があります。これには時間がかかり、ネットワークに不要なトラフィックが発生します。このように使用してください:

var template = $('#templates #example_template').detach();
var clone = template.clone();
clone.find('.some_field').val('new_data');
clone.attr('id', null);
$('table tbody').append(clone);

11
完全ではありません。 .trigger2つの引数のみを取ります。パラメータの配列(またはオブジェクト)を渡す必要があります。
ロケット危険物2013年

私の例のように、イベントバインディングをイベントハンドラーから分離したい場合、正しい構文は何でしょうか?
user517406 2013年

構文例を教えてください。この構文の使用は機能しません。EVENTBINDING$(window).on( 'onPartialRendered'、onPartialRendered(p1、p2)); イベントハンドラーvaronPartialRendered = function(p1、p2){...}
user517406 2013年

2
@ user517406これは、関数参照をイベントハンドラーとして渡すための完全に間違った方法です。関数を定義する場所にパラメーターを追加します。var onPartialRendered = function (event,one,two) {
ケビンB

2
トリガーを次のように変更するだけです:$( 'body')。trigger({type: 'this_works'、data:[1,2,3]、message: 'something'});。ハンドラーには、function(event)を含めるだけで、event.dataとevent.messageを指定してパラメーターを取得できます。
linnium 2014年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.