語法
在諸如 addEventListener() 之類的方法中使用事件名稱,或設定事件處理程式屬性。
js
addEventListener("compositionend", (event) => { })
oncompositionend = (event) => { }
事件型別
一個 CompositionEvent 物件。繼承自 UIEvent 和 Event。
事件屬性
此介面還繼承了其父介面 UIEvent 及其祖先介面 Event 的屬性。
CompositionEvent.data只讀-
返回由觸發事件的輸入法生成的字元;具體返回值取決於生成
CompositionEvent物件的事件型別。 CompositionEvent.locale只讀 已棄用-
返回當前輸入法的 locale(例如,如果合成與 輸入法編輯器 相關聯,則返回鍵盤佈局的 locale)。
示例
js
const inputElement = document.querySelector('input[type="text"]');
inputElement.addEventListener("compositionend", (event) => {
console.log(`generated characters were: ${event.data}`);
});
即時示例
HTML
html
<div class="control">
<label for="example">
First select textbox, then to open IME:
<ul>
<li>on macOS type <kbd>option</kbd> + <kbd>`</kbd></li>
<li>on Windows type <kbd>windows</kbd> + <kbd>.</kbd></li>
</ul>
</label>
<input type="text" id="example" name="example" />
</div>
<div class="event-log">
<label for="eventLog">Event log:</label>
<textarea
readonly
class="event-log-contents"
rows="8"
cols="25"
id="eventLog"></textarea>
<button class="clear-log">Clear</button>
</div>
JavaScript
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 += `${event.type}: ${event.data}\n`;
}
inputElement.addEventListener("compositionstart", handleEvent);
inputElement.addEventListener("compositionupdate", handleEvent);
inputElement.addEventListener("compositionend", handleEvent);
結果
規範
| 規範 |
|---|
| UI 事件 # event-type-compositionend |
瀏覽器相容性
載入中…