Recipe 9.1
Status: idle
Dictating Text
Compatibility Note: Speech Recognition API
This feature may not be supported on all browsers yet. Please check the latest compatibility data before using in a production application.
Browser support for Speech Recognition APIClick the blue microphone button to start dictating. Click the X to stop.
Demo
This browser does not support the Web Speech API.
Code
JavaScript
const toggle = document.querySelector('#dictate');
const icon = toggle.firstElementChild;
const statusTag = document.querySelector('#status');
const result = document.querySelector('#result');
let recognition;
/**
* Starts listening for speech. When speech is recognized, it is appended
* to the given text field's value.
* Recognition continues until the returned recognition object is stopped.
*
* @param textField A text field to append to
* @returns The recognition object
*/
function startDictation(textField) {
if ('webkitSpeechRecognition' in window || 'SpeechRecognition' in window) {
const SpeechRecognition = window.SpeechRecognition || window.webkitSpeechRecognition;
const recognition = new SpeechRecognition();
recognition.continuous = true;
recognition.maxAlternatives = 50;
recognition.addEventListener('result', event => {
const result = event.results[event.resultIndex];
console.log(result);
textField.value += result[0].transcript;
});
recognition.addEventListener('error', event => {
console.log('error', event);
});
recognition.start();
// Return the recognition object so recognition
// can be stopped later (like when the user clicks a toggle button).
return recognition;
}
}
// Make sure the browser supports speech recognition.
if (!('webkitSpeechRecognition' in window || 'SpeechRecognition' in window)) {
document.querySelector('.compatibility').classList.remove('d-none');
document.querySelector('.demo').classList.add('d-none');
}
toggle.addEventListener('click', () => {
if (recognition) {
recognition.stop();
statusTag.className = 'badge text-bg-secondary';
statusTag.textContent = 'idle';
icon.className = 'bi bi-mic-fill';
} else {
recognition = startDictation(result);
statusTag.className = 'badge text-bg-primary';
statusTag.textContent = 'listening';
icon.className = 'bi bi-x-circle-fill';
}
});
HTML
<div class="compatibility mb-0 d-none alert alert-warning" role="alert">
<i class="bi bi-exclamation-triangle me-2"></i>
This browser does not support the Web Speech API.
</div>
<div class="demo">
<div class="d-flex align-items-start">
<textarea id="result" class="form-control" placeholder="Click the microphone icon to start dictating..."></textarea>
<button id="dictate" class="btn btn-primary ms-2"><i class="bi bi-mic-fill"></i></button>
</div>
Status: <span id="status" class="badge text-bg-secondary">idle</span>
</div>