Webブラウザのイベント処理1
【開発環境】
OS;Window10
Webブラウザ:Google Chrome
テキストエディタ:Brackets
---イベント処理の基礎知識---
【イベントと、イベントハンドラ】
イベントとは→ユーザがボタンをクリックしたり、テキストボックスに文字を入れて【Enter】キーをおした時に、ブラウザから送出されるメッセージのようなものです。
イベントハンドラ→発生したイベントを捕まえて、それに対して何らかの処理を行うプログラムの事。
data:image/s3,"s3://crabby-images/110c2/110c282e74229b82f602d742910485113d135a45" alt=""
・イベント処理の3つの方法
1)HTMLタグの属性で設定する
2)エレメントオブジェクトのプロパティとして設定する
3)イベントリスナーで設定する
◆HTMLタグの属性で処理を設定する
ア)ボタンのクリックを捕まえる
・ボタンの設定
<input type="button" value="クリックして" id="myBtn"
・イベントハンドラの設定
onclick="alert('クリックされました'); console.log('クリックされました')">
data:image/s3,"s3://crabby-images/f500c/f500cd62220f959dc3d2514aa00053bfac2e2193" alt=""
「クリック」ボタンをクリックする→アラートダイアログ表示
data:image/s3,"s3://crabby-images/5c41f/5c41f651722835addd2f37a4f9ccf5f3b6d451b8" alt=""
イ)イベントハンドラを関数に!
例文
data:image/s3,"s3://crabby-images/a7223/a72237d37f2a29ae80eee6de5bec526da8aabdb7" alt=""
同じ結果に成る
ウ)イベントが発生したエレメントを調べる→「this」を使う。
・例文
省略
<body>
<input type="button" value="クリックして" id="myBtn" onclick="clickHandler(this)">
<script>
function clickHandler(el) {
alert(el.id + "がクリックされました");
}
</script>
</body>
実行
・「クリック」ボタンをを押すと、アラートダイアログが表示される
data:image/s3,"s3://crabby-images/c86a2/c86a29ca9b3e10ebbe014c51893c932ad923a78f" alt=""
◆オブジェクトのプロパティとしてイベントハンドラを設定する
ア)onclickプロパティにコールバック関数を登録
例えば、「myBtn」ボタンを設け、それがクリックされた時に呼び出されるイベントハンドラの関数を登録するには、下記のようにする。
書式
myBtn.onclick = 関数;
例文
data:image/s3,"s3://crabby-images/3cb7f/3cb7f4e9785c3e499b4c1218397f54c00c63b366" alt=""
var myBtn = document.getElementById("myBtn");→ドキュメント要素を取得している
myBtn.onclick = clickHandler;→関数を登録している
実行する
data:image/s3,"s3://crabby-images/63c95/63c95fbae237e2f5f6d1b6da0282d7feb0a8a53a" alt=""
◆コールバック関数を無名関数にする
無名関数→一度しか呼ばない関数
例文
data:image/s3,"s3://crabby-images/fbfce/fbfce94ea63fa7bf66ed96f75b3844495a580a03" alt=""
実行
data:image/s3,"s3://crabby-images/9e1f2/9e1f2fd0e83b78e6b419c0c341cd199feb705d7c" alt=""
◆イベントハンドラを削除する
プロパティに代入した後に、イベントハンドラを削除することができる。
element.onclick = null;
◆イベントハンドラとして使用するプロパティ
data:image/s3,"s3://crabby-images/f6be2/f6be2f8d20c4b028c2ec9827b465883feed887a0" alt=""
◆onloadイベントハンドラ
HTMLドキュメントの読み込みが完了したときのイベントを呼び込む、イベントハンドラ
例文
data:image/s3,"s3://crabby-images/b4c4c/b4c4c4a6803e426fdbc006b4300c75cf458f2b18" alt=""
実行
data:image/s3,"s3://crabby-images/e7e7b/e7e7b320fcb5b7682d3bb43ac11ef8a99f3457e8" alt=""
・onloadはheadエレメントにプログラムを記述する時に必要
headエレメントに書くと、エラーになり、動作しない。
なぜなら、すべてのエレメントが読み込まれてないからである。
data:image/s3,"s3://crabby-images/0c462/0c4624718170c93e82616f3f23766d68d3c869b9" alt=""
改造後→windowのonloadイベンドハンドラに処理を記述すれば良い。そうすることで、HTMLドキメントのロード完了待ってから処理を実行できる。
data:image/s3,"s3://crabby-images/97ba0/97ba00e429c1ccd7956243e811e0f69d03497aa3" alt=""
表示
data:image/s3,"s3://crabby-images/6c5dd/6c5dd81fc3676a26b449e416b4ef528e490135b4" alt=""
※コメント投稿者のブログIDはブログ作成者のみに通知されます