質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

3回答

321閲覧

JavaScriptで状態が変わると呼び出されるイベントリスナーの作り方

Paalon

総合スコア232

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2019/08/21 05:07

グラフィカルユーザーインターフェイスのあるプログラムをあまり書いたことがないのですが、自作のクラスから生成されたオブジェクトの状態が変わるたびに描画する関数を呼び出すために素の JavaScript? にある onclickonload のようなイベントハンドラー?リスナー?を作るにはどうすれば良いのでしょうか?
もう少し具体的に書くと、

javascript

1class GameState { 2 constructor(state) { 3 this.state = state; 4 } 5 change(state) { 6 this.state = state; 7 } 8} 9 10game_state.onchanged = () => { 11 render(game_state); 12}; 13 14let game_state = new GameState("aaa"); 15game_state.change("bbb"); // render が呼ばれる

のようなことをしたいです。
ブラウザのJavaScript環境は普通のブラウザで動く最新のものだけ考慮すれば良いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

プロパティ監視は二通りの実装があります。

  • get/set キーワードで getter,setter を定義し、値の実体を WeakMap でプライベートプロパティを定義する要領で実装する
  • new Proxy でプロパティ監視

イベントハンドラへの引き渡しは、お好きな方法を選択して下さい。

  • コールバック関数で渡す
  • dispatchEvent
  • 独自のイベント駆動classを定義

Re: Paalon さん

投稿2019/08/21 09:44

think49

総合スコア18164

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自作のchange処理にrenderを記載すればよいのでは?

投稿2019/08/21 05:14

yambejp

総合スコア114843

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Paalon

2019/08/21 05:42

場合によって異なるrenderの関数を渡したいので後から変更できるようにしたいです。
guest

0

関数を登録するメソッドを作って、当該(change)動作の時に登録した関数を全て実行すればよいのでは。

投稿2019/08/21 07:40

kei344

総合スコア69407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問