If you're curious about trying this out, that's the 3 lines of code below š
var msg = new SpeechSynthesisUtterance();
msg.text = "Hello World";
window.speechSynthesis.speak(msg);
But if you're not in a hurry, this article explains everything you need to know about converting text to speech (spoken words) on the web with JavaScript.
Introduction
In a previous article, we'd explored the Web Speech API and also how to convert Speech To Text
Another amazing feature of the Web Speech API is to convert Text to Speech.
Note: Text To Speech != Speech To Text š§
- Text To Speech is when we give the computer some words and the computer will say this words out loud in some robotic/human voice. While
- Speech To Text is when we say some words to the computer, and what we'd just said will be converted to text (I guess this is explanatory enough)
Getting Started
The first thing we'll need to do is check if our browser supports the speech synthesis API. And the code below does that:
if ('speechSynthesis' in window) {
Ā // Speech Synthesis supported š
}else{
// Speech Synthesis Not Supported š£
alert("Sorry, your browser doesn't support text to speech!");
}
Next step is to create a new speechSynthesis object, add required property and make our app talk š
var msg = new SpeechSynthesisUtterance();
msg.text = "Good Morning";
window.speechSynthesis.speak(msg);
Code Explanation
- Line 1: We created a variable
msg, and the value assigned to it is a new instance of thespeechSynthesisclass. - Line 2: The
.textproperty is used to specify the text we want to convert to speech - And finally, the code on the 3rd(last) line is what actually make our browser talks.
Altering Default Output
The speechSynthesis API gives room to also change alter the default output like changing the voice, volume, speech rate, language, pitch and more:
var msg = new SpeechSynthesisUtterance();
var voices = window.speechSynthesis.getVoices();
msg.voice = voices[10];
msg.volume = 1; // From 0 to 1
msg.rate = 1; // From 0.1 to 10
msg.pitch = 2; // From 0 to 2
msg.text = "Como estas Joel";
msg.lang = 'es';
speechSynthesis.speak(msg);
Getting Supported Voices
The code below helps you retrieve the list of all supported voices:
speechSynthesis.getVoices().forEach(function(voice) {
Ā console.log(voice.name, voice.default ? voice.default :'');
});
Conclusion
Well, there's nothing to conclude here I guess š
But you could follow me on Twitter, I tweet and retweet interesting technical stuffs; you sure want to see em.
Thanks for reading š
Latest comments (31)
Wow, what a find - thank you very much
I didn't know it is built in. Awesome
Great, how can download the voice
I can do it one in one line of code:
window.speechSynthesis.speak(new SpeechSynthesisUtterance("Hello World"));š
NOTE:
getVoicesdoesn't work on page load in Chrome. See StackOverflow: Getting the list of voices in speechSynthesis (Web Speech API)Thank @asaoluelijah
How to read the web page content? suppose in html page we have
hii gud morning
how do we take reference for the p tag in order to speak the content inside the p tag?You can add an id in p tag
say, id="content" is added in p tag
now access the content inside the p tag using this id and replace in above code like this:
msg.text = document.getElementById("content").textContent;
Mind blown. Thanks! That's what Stephen Hawking used, right? :D
Might be! :D
Nice. Any idea how to make it sound more human?
I am not getting make the code to work.
I am using firefox in linux OS
The browser can detect the SpeechSynthesisUtterance() but there is no voice or
any sound. I noticed that window.speechSynthesis.getVoices() don't return any voice.
You will need to have a text-to-speech dispatcher installed first, otherwise there's no TTS to use. See wiki.archlinux.org/title/List_of_a... for reference.