📤
Stimulusでコントローラー間のデータ連携
Stimulusでコントローラー間のデータやりとりはどうすればいいのか?
調べてみるとカスタムイベントを使う手法が紹介されていた。
Communicating between Stimulus controllers using custom events
リンク先のコードが十分小さいので理解しやすいが、「+1」ボタンをクリックすると結果に足される例。
HTMLではボタンにcountup
コントローラーを割り当て、クリックするとcountup
コントローラーのclick
メソッドが呼び出される。その結果カスタムイベントplusone
が発信される。
一方result
コントローラーはplusone
イベントをupdate
メソッドで処理するようになっている。
<button data-controller="countup" data-action="click->countup#click">+1</button>
<div data-controller="result" data-action="plusone@window->result#update"></div>
click
メソッドでカスタムイベントを作ってdetail
プロパティに渡したい値を設定する。そしてdispatchEvent
でカスタムイベントを発信。
// countup_controller.js
import { Controller } from "stimulus"
export default class extends Controller {
click() {
const event = new CustomEvent('plusone', { detail: 1 })
window.dispatchEvent(event);
}
}
イベントの受け手はカスタムイベントのdetail
プロパティを好きなように処理する。この場合は合計に足して、HTMLに結果を表示するようにしている。
// result_controller.js
import { Controller } from "stimulus"
export default class extends Controller {
initialize() {
this.sum = 0;
this.element.innerHTML = this.sum;
}
update(event) {
if (event.detail) {
this.sum += event.detail;
this.element.innerHTML = this.sum;
}
}
}
カスタムイベントすごい便利で簡単!という印象だが、これ以上複雑になったらどうしようという心配もある。
Discussion