--- title: compositionstart slug: Web/API/Element/compositionstart_event tags: - Element - Event - Input method - Reference - compositionstart translation_of: Web/API/Element/compositionstart_event original_slug: Web/Events/compositionstart ---
L'événement compositionstart est déclenché lorsqu'un système de composition de texte tel qu'une {{glossary("input method editor","méthode de saisie")}} démarre une nouvelle session de composition.
Par exemple, cet événement pourrait être déclenché après qu'un utilisateur a commencé à saisir un caractère chinois en utilisant un Pinyin IME.
| Propagation | Oui |
|---|---|
| Annulable | Oui |
| Interface | {{domxref("CompositionEvent")}} |
| Propriété du gestionnaire d'événements | Aucune |
const inputElement = document.querySelector('input[type="text"]');
inputElement.addEventListener('compositionstart', (event) => {
console.log(`generated characters were: ${event.data}`);
});
<div class="control"> <label for="name">Sur macOS, cliquez dans la zone de texte ci-dessous,<br> puis tapez <kbd>option</kbd> + <kbd>`</kbd>, puis <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>
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);
{{ EmbedLiveSample('Live_example', '100%', '180px') }}
| Spécification | Statut |
|---|---|
| {{SpecName('UI Events', '#event-type-compositionstart')}} | {{Spec2('UI Events')}} |
{{Compat("api.Element.compositionstart_event")}}