JavaScript純前端實現(xiàn)語音播報和朗讀功能
實現(xiàn)語音播報要有兩個原生API
分別是【window.speechSynthesis】【SpeechSynthesisUtterance】
項目代碼
// 執(zhí)行函數 initVoice({ text: '項目介紹', vol: 1, rate: 1 }) // 函數 export function initVoice(config) { window.speechSynthesis.cancel();//播報前建議調用取消的函數,如有正在播報的話音,播報會任務被塞進入隊列,只有等上一個語音結束才會執(zhí)行下一個語音 //獲取語音包 let listArr = window.speechSynthesis.getVoices(); listArr = listArr.filter(item => item.lang.indexOf('zh-') > -1); if (listArr.length == 0) { console.error('沒有可用的中文語音!'); } //實例化播報內容 let instance = new SpeechSynthesisUtterance(); instance.text = config.text || '輕輕敲醒沉睡的心靈,慢慢張開你的眼睛,看看忙碌的世界,是否依然孤獨的轉個不停!'; // 文字內容 instance.lang = config.lang || "zh-CN"; // 使用的語言:中文 instance.volume = config.vol || 1; // 聲音音量:1 instance.rate = config.rate || 1; // 語速:1 instance.pitch = 1; // 音高:1 window.speechSynthesis.speak(instance); // 播放 instance.addEventListener("end", () => {});// 監(jiān)聽播報完成狀態(tài),播完可以做些其它處理 }
將函數拷貝到項目中,執(zhí)行函數即可實現(xiàn)。
下面列出一些常用的執(zhí)行方法
//獲取可用的語音包,如果返回數組是空,則沒有可用的語音包。不同瀏覽器的語音包數量是不一樣的。 window.speechSynthesis.getVoices(); //instance是SpeechSynthesisUtterance的實例,綁定了語音包。將話語添加到話語隊列中;當任何其他話語在它被說出之前排隊時,它將被說出。 window.speechSynthesis.speak(instance); // 取消語音 window.speechSynthesis.cancel(); //暫停語音 // window.speechSynthesis.pause(); //恢復語音 window.SpeechSynthesis.resume();
注意:在某些瀏覽器,必須先提前調用【window.speechSynthesis.getVoices();】方法,再異步執(zhí)行上面【完整語音播報】再能播報語音。
原因是第一次【window.speechSynthesis.getVoices();】獲取的數據是空數組。
第二次異步調用【window.speechSynthesis.getVoices();】才返回非空數組。
到此這篇關于JavaScript純前端實現(xiàn)語音播報和朗讀功能的文章就介紹到這了,更多相關JavaScript語音播報朗讀內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
webpack項目使用eslint建立代碼規(guī)范實現(xiàn)
這篇文章主要介紹了webpack項目使用eslint建立代碼規(guī)范實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05用JavaScript實現(xiàn)一個代碼簡潔、邏輯不復雜的多級樹
這篇文章主要介紹了用JavaScript實現(xiàn)一個代碼簡潔、邏輯不復雜的多級樹,需要的朋友可以參考下2014-05-05