Element: compositionstart イベント
compositionstart
イベントは、 IME などのテキスト変換システムが新しい変換セッションを開始した時に発生します。
例えば、このイベントはユーザーがピン音 IME を使用して漢字の入力を開始した後に発生します。
バブリング | あり |
---|---|
キャンセル | 可 |
インターフェイス | CompositionEvent |
イベントハンドラープロパティ | なし |
例
const inputElement = document.querySelector('input[type="text"]');
inputElement.addEventListener('compositionstart', (event) => {
console.log(`generated characters were: ${event.data}`);
});
実行例
HTML
<div class="control">
<label for="name">On macOS, click in the textbox below,<br> then type <kbd>option</kbd> + <kbd>`</kbd>, then <kbd>a</kbd>:</label>
<input type="text" id="example" name="example">
</div>
<div class="event-log">
<label>Event log:</label>
<textarea readonly class="event-log-contents" rows="8" cols="25"></textarea>
<button class="clear-log">Clear</button>
</div>
JS
const inputElement = document.querySelector('input[type="text"]');
const log = document.querySelector('.event-log-contents');
const clearLog = document.querySelector('.clear-log');
clearLog.addEventListener('click', () => {
log.textContent = '';
});
function handleEvent(event) {
log.textContent = log.textContent + `${event.type}: ${event.data}\n`;
}
inputElement.addEventListener('compositionstart', handleEvent);
inputElement.addEventListener('compositionupdate', handleEvent);
inputElement.addEventListener('compositionend', handleEvent);
結果
仕様書
Specification |
---|
UI Events # event-type-compositionstart |
ブラウザーの互換性
BCD tables only load in the browser
関連情報
- 関連イベント:
compositionend
,compositionupdate
。