JavaScript純前端實現(xiàn)語音播報和朗讀功能
實現(xiàn)語音播報要有兩個原生API
分別是【window.speechSynthesis】【SpeechSynthesisUtterance】
項目代碼
// 執(zhí)行函數(shù)
initVoice({
text: '項目介紹',
vol: 1,
rate: 1
})
// 函數(shù)
export function initVoice(config) {
window.speechSynthesis.cancel();//播報前建議調(diào)用取消的函數(shù),如有正在播報的話音,播報會任務(wù)被塞進入隊列,只有等上一個語音結(jié)束才會執(zhí)行下一個語音
//獲取語音包
let listArr = window.speechSynthesis.getVoices();
listArr = listArr.filter(item => item.lang.indexOf('zh-') > -1);
if (listArr.length == 0) {
console.error('沒有可用的中文語音!');
}
//實例化播報內(nèi)容
let instance = new SpeechSynthesisUtterance();
instance.text = config.text || '輕輕敲醒沉睡的心靈,慢慢張開你的眼睛,看看忙碌的世界,是否依然孤獨的轉(zhuǎn)個不停!'; // 文字內(nèi)容
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),播完可以做些其它處理
}將函數(shù)拷貝到項目中,執(zhí)行函數(shù)即可實現(xiàn)。
下面列出一些常用的執(zhí)行方法
//獲取可用的語音包,如果返回數(shù)組是空,則沒有可用的語音包。不同瀏覽器的語音包數(shù)量是不一樣的。 window.speechSynthesis.getVoices(); //instance是SpeechSynthesisUtterance的實例,綁定了語音包。將話語添加到話語隊列中;當(dāng)任何其他話語在它被說出之前排隊時,它將被說出。 window.speechSynthesis.speak(instance); // 取消語音 window.speechSynthesis.cancel(); //暫停語音 // window.speechSynthesis.pause(); //恢復(fù)語音 window.SpeechSynthesis.resume();

注意:在某些瀏覽器,必須先提前調(diào)用【window.speechSynthesis.getVoices();】方法,再異步執(zhí)行上面【完整語音播報】再能播報語音。
原因是第一次【window.speechSynthesis.getVoices();】獲取的數(shù)據(jù)是空數(shù)組。
第二次異步調(diào)用【window.speechSynthesis.getVoices();】才返回非空數(shù)組。

到此這篇關(guān)于JavaScript純前端實現(xiàn)語音播報和朗讀功能的文章就介紹到這了,更多相關(guān)JavaScript語音播報朗讀內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Jquery把獲取到的input值轉(zhuǎn)換成json
本篇文章主要介紹了Jquery把獲取到的input值轉(zhuǎn)換成json的相關(guān)知識,具有很好的參考價值。下面跟著小編一起來看下吧2017-05-05
javascript實現(xiàn)表格排序 編輯 拖拽 縮放
這篇文章主要介紹了javascript實現(xiàn)表格排序 編輯 拖拽 縮放的方法,效果非常不錯,只是兼容性還有些問題,有待優(yōu)化。2015-01-01
JavaScript?進階問題列表(各種js代碼段108-155)
從基礎(chǔ)到進階,測試你有多了解?JavaScript,刷新你的知識,或者幫助你的?coding?面試!?:muscle:?:rocket:?我每周都會在這個倉庫下更新新的問題2024-11-11
js實現(xiàn)左側(cè)網(wǎng)頁tab滑動門效果代碼
這篇文章主要介紹了js實現(xiàn)左側(cè)網(wǎng)頁tab滑動門效果代碼,涉及JavaScript頁面元素的遍歷及元素屬性動態(tài)切換的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09
JavaScript從數(shù)組(數(shù)組對象)中刪除特定數(shù)據(jù)的方法
這篇文章主要給大家介紹了關(guān)于JavaScript從數(shù)組(數(shù)組對象)中刪除特定數(shù)據(jù)的相關(guān)資料,js在前臺界面中舉足輕重,在使用js刪除數(shù)組時遇到一些問題,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
使用js判斷TextBox控件值改變?nèi)缓蟪霭l(fā)事件
這篇文章主要介紹了使用js判斷TextBox控件值改變?nèi)缓蟪霭l(fā)事件。需要的朋友可以過來參考下,希望對大家有所幫助2014-03-03

