欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript純前端實現(xiàn)語音播報和朗讀功能

 更新時間:2024年04月16日 14:43:37   作者:寶,卡粉了  
這篇文章主要為大家詳細介紹了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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論