1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
|
---
title: イベントの作成と起動
slug: Web/Events/Creating_and_triggering_events
tags:
- 上級者
- DOM
- ガイド
- JavaScript
- NeedsContent
- イベント
translation_of: Web/Events/Creating_and_triggering_events
original_slug: Web/Events/Creating_and_triggering_events
---
この記事では、 DOM イベントを作成して処理する方法を説明します。このようなイベントは、一般に、ブラウザー自体によって起動されたイベントとは対照的に、**合成イベント**と呼ばれます。
## カスタムイベントの作成
イベントは、次のように [`Event`](/ja/docs/Web/API/Event) コンストラクターを使用して作成できます。
```js
const event = new Event('build');
// Listen for the event.
elem.addEventListener('build', function (e) { /* ... */ }, false);
// Dispatch the event.
elem.dispatchEvent(event);
```
上記のコード例は [EventTarget.dispatchEvent()](/ja/docs/Web/API/EventTarget/dispatchEvent) メソッドを使用します。
このコンストラクターは、ほとんどの最新のブラウザーでサポートされています (Internet Explorer は例外です)。もっと冗長的なアプローチ (Internet Explorer で動作するもの) は、下記の[古い方法](#古い方法)を参照して下さい。
### カスタムデータの追加 – CustomEvent()
イベントオブジェクトにデータを追加するには、[CustomEvent](/ja/docs/Web/API/CustomEvent) インターフェイスが存在し、**detail** プロパティを使用してカスタムデータを渡すことができます。
たとえば、イベントは次のようにして作成することができます。
```js
const event = new CustomEvent('build', { detail: elem.dataset.time });
```
これにより、イベントリスナー内の追加データにアクセスすることができます。
```js
function eventHandler(e) {
console.log('The time is: ' + e.detail);
}
```
### 古い方法
イベントを作成する古いアプローチでは、 Java に触発された API が使用されます。以下に例を示します。
```js
/ イベントの作成
const event = document.createEvent('Event');
// イベントの名前を 'build' と定義する
event.initEvent('build', true, true);
// イベントを待ち受けする
elem.addEventListener('build', function (e) {
// e.target が elem と一致したとき
}, false);
// 対象が何らかの Element またはその他の EventTarget の場合
elem.dispatchEvent(event);
```
### イベントのバブリング
子要素からイベントを起動させ、祖先要素がそれを、任意でデータも、受け取りたい場合がよくあります。
```html
<form>
<textarea></textarea>
</form>
```
```js
const form = document.querySelector('form');
const textarea = document.querySelector('textarea');
// 新しいイベントを生成し、バブリングを許可し、 "detail" プロパティに渡したいデータを設定する
const eventAwesome = new CustomEvent('awesome', {
bubbles: true,
detail: { text: () => textarea.value }
});
// フォームイベントが "awesome" カスタムイベントを待ち受けし、渡されたものの text() メソッドをコンソールに出力する
form.addEventListener('awesome', e => console.log(e.detail.text()));
// ユーザー型の場合、 form 内の textarea は発生させるイベントを起動・処理し、それを開始点として使用する
textarea.addEventListener('input', e => e.target.dispatchEvent(eventAwesome));
```
### イベントの動的な生成と処理
要素はまだ作成されていないイベントを待ち受けすることができます。
```html
<form>
<textarea></textarea>
</form>
```
```js
const form = document.querySelector('form');
const textarea = document.querySelector('textarea');
form.addEventListener('awesome', e => console.log(e.detail.text()));
textarea.addEventListener('input', function() {
// Create and dispatch/trigger an event on the fly
// Note: Optionally, we've also leveraged the "function expression" (instead of the "arrow function expression") so "this" will represent the element
this.dispatchEvent(new CustomEvent('awesome', { bubbles: true, detail: { text: () => textarea.value } }))
});
```
### 組み込みイベントの起動
この例では、 DOM メソッドを使用してチェックボックスでクリック (プログラムでクリックイベントを生成する) をシミュレートする方法を示します。[デモを見る](https://media.prod.mdn.mozit.cloud/samples/domref/dispatchEvent.html)。
```js
function simulateClick() {
const event = new MouseEvent('click', {
view: window,
bubbles: true,
cancelable: true
});
const cb = document.getElementById('checkbox');
const cancelled = !cb.dispatchEvent(event);
if (cancelled) {
// A handler called preventDefault.
alert("cancelled");
} else {
// None of the handlers called preventDefault.
alert("not cancelled");
}
}
```
## 関連情報
- [CustomEvent()](/ja/docs/Web/API/CustomEvent/CustomEvent)
- {{domxref("document.createEvent()")}}
- {{domxref("Event.initEvent()")}}
- {{domxref("EventTarget.dispatchEvent()")}}
- {{domxref("EventTarget.addEventListener()")}}
<section id="Quick_links"><ul><li><a href="/ja/docs/Learn/JavaScript/Building_blocks/Events">イベント入門</a></li><li><a href="/ja/docs/Web/Events/Event_handlers">イベントハンドラー (概要)</a></li><li><a href="/ja/docs/Web/Events">イベントリファレンス</a></li></ul></section>
|