---
title: compositionstart
slug: Web/API/Element/compositionstart_event
translation_of: Web/API/Element/compositionstart_event
original_slug: Web/Events/compositionstart
---
{{APIRef}}
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](https://en.wikipedia.org/wiki/Pinyin) IME.
Propagation
Oui
Annulable
Oui
Interface
{{domxref("CompositionEvent")}}
Propriété du gestionnaire d'événements
Aucune
## Exemples
```js
const inputElement = document.querySelector('input[type="text"]');
inputElement.addEventListener('compositionstart', (event) => {
console.log(`generated characters were: ${event.data}`);
});
```
### Exemple concret
#### HTML
```html
Sur macOS, cliquez dans la zone de texte ci-dessous, puis tapez option + ` , puis a :
Event log:
Clear
```
```css hidden
body {
padding: .2rem;
display: grid;
grid-template-areas: "control log";
}
.control {
grid-area: control;
}
.event-log {
grid-area: log;
}
.event-log-contents {
resize: none;
}
label, button {
display: block;
}
input[type="text"] {
margin: .5rem 0;
}
kbd {
border-radius: 3px;
padding: 1px 2px 0;
border: 1px solid black;
}
```
#### JS
```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);
```
#### Résultat
{{ EmbedLiveSample('Exemple_concret', '100%', '180px') }}
## Spécifications
| Spécification | Statut |
| ---------------------------------------------------------------------------- | ---------------------------- |
| {{SpecName('UI Events', '#event-type-compositionstart')}} | {{Spec2('UI Events')}} |
## Compatibilités navigateur
{{Compat("api.Element.compositionstart_event")}}
## Voir aussi
- Événements liés : {{domxref("Element/compositionend_event", "compositionend")}}, {{domxref("Element/compositionupdate_event", "compositionupdate")}}.