LoginSignup
9
8

More than 5 years have passed since last update.

[KnockoutJS]フォーム入力中のEnterによるイベントを発生させるには

Posted at

KnockoutJSの標準のイベントにEnterキー押下のものはありません(今もないはず)。
なので、独自に追加しないといけません。
といってもbindinghandlersから簡単に追加できます。

// knockout初期化前に記述すること
ko.bindingHandlers.executeOnEnter = {
  init: function (element, valueAccessor, allBindingsAccessor, viewModel) {
    var allBindings = allBindingsAccessor();
    // ここではjQueryを使ってますが、イベント拾えれば何でもいいです
    $(element).keypress(function (event) {
      var keyCode = event.which || event.keyCode;
      if (keyCode === 13) { // Enterキーだった場合
        allBindings.executeOnEnter.call(viewModel);
      }
    });
  }
};

var viewModel = {
  search: function () {
    // ここで検索を実行するとする
    alert("けんさく!けんさく!");
  }
}

ko.applyBindings(viewModel);

イベントを追加したら、clickなどと同じ感覚でdata-bindに追加してください。

<input data-bind="value: query, valueUpdate: 'afterkeydown', executeOnEnter: search" />

これでフォーム入力中のEnterからviewModel.search()が実行されるようになりました。
bindingHandlersはKnockoutJSでゴニョゴニョやろうとすると必ずぶち当たります。
自分もまだよく理解出来ていないので、当面はTipsを載せるだけ・・・。

jsFiddle

サンプルは以下。
http://jsfiddle.net/nantekkotai/Z5QDf/

9
8
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
8