1. ホーム
  2. javascript

[解決済み] JQuery .triggerでパラメータを渡す

2023-04-30 18:33:33

質問

JQueryトリガーを使用していますが、私の状況下でパラメータを渡すための正しい構文がわかりません。 私が呼び出している場所はここにあります。

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

ここで、イベントバインディングを行っています。

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

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

var onPartialRendered = function () {

    .....
};

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

どのように解決するのですか?

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

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

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

Rocket Hazmat に感謝します。

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);