亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

原生JavaScript再網(wǎng)頁(yè)實(shí)現(xiàn)文本轉(zhuǎn)語(yǔ)音功能

 更新時(shí)間:2025年03月17日 15:52:30   作者:bbamx.  
這篇文章主要為大家詳細(xì)介紹了如何通過(guò)原生JavaScript再網(wǎng)頁(yè)實(shí)現(xiàn)文本轉(zhuǎn)語(yǔ)音功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

1、原理

語(yǔ)音合成 (也被稱作是文本轉(zhuǎn)為語(yǔ)音,英語(yǔ)簡(jiǎn)寫是 tts) 包括接收 app 中需要語(yǔ)音合成的文本,再在設(shè)備麥克風(fēng)播放出來(lái)這兩個(gè)過(guò)程。

Web API中對(duì)此有一個(gè)主要控制接口 SpeechSynthesis,外加一些處理如何表示要被合成的文本 (也被稱為 utterances),用什么聲音來(lái)播出 utterances 等工作的相關(guān)接口。同樣的,許多操作系統(tǒng)都有自己的某種語(yǔ)音合成系統(tǒng),在這個(gè)任務(wù)中我們調(diào)用可用的 API 來(lái)使用語(yǔ)音合成系統(tǒng)。

2、示例

可以直接復(fù)制下面代碼運(yùn)行在瀏覽器中

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/axios/1.5.0/axios.js"></script>
  </head>
  <body>
    <div>
      <input type="text" />
      <button>開(kāi)始播放語(yǔ)音</button>
    </div>
  </body>
  <script>
    const btn = document.querySelector('button')
    const ipt = document.querySelector('input')
 
    function speak({ text, speechRate, lang, volume, pitch }, endEvent, startEvent) {
      if (!window.SpeechSynthesisUtterance) {
        console.warn('當(dāng)前瀏覽器不支持文字轉(zhuǎn)語(yǔ)音服務(wù)')
        return
      }
      if (!text) {
        return
      }
      const speechUtterance = new SpeechSynthesisUtterance()
      speechUtterance.text = text
      speechUtterance.rate = speechRate || 1
      speechUtterance.lang = lang || 'zh-CN'
      speechUtterance.volume = volume || 1
      speechUtterance.pitch = pitch || 1
      speechUtterance.onstart = function (e) {
        startEvent && startEvent()
      }
      speechUtterance.onend = function (e) {
        endEvent && endEvent()
      }
      speechSynthesis.speak(speechUtterance)
 
      return speechUtterance
    }
 
    btn.addEventListener('click', function () {
      if (!ipt.value) return
      speak(
        {
          text: ipt.value,
        },
        function () {
          console.log('語(yǔ)音播放結(jié)束')
        },
        function () {
          console.log('語(yǔ)音開(kāi)始播放')
        }
      )
    })
  </script>
</html>

支持的瀏覽器

  • Firefox 桌面版和移動(dòng)版。
  • Firefox OS 2.5+。
  • Chrome 桌面版和安卓版。

注意:如果效果演示失敗,大概是由于您當(dāng)前使用的瀏覽器不支持語(yǔ)音轉(zhuǎn)文字這個(gè)API,請(qǐng)更換瀏覽器后重試!

3、解析speak函數(shù)

接受參數(shù)

  • text:要轉(zhuǎn)換為語(yǔ)音的文本內(nèi)容。
  • speechRate:語(yǔ)音播放速率。
  • lang:語(yǔ)音的語(yǔ)言代碼。
  • volume:語(yǔ)音的音量。
  • pitch:語(yǔ)音的音調(diào)。

1、另外,它還接受兩個(gè)回調(diào)函數(shù)作為參數(shù):endEvent 和 startEvent。endEvent 在語(yǔ)音播放結(jié)束時(shí)觸發(fā),而 startEvent 在語(yǔ)音播放開(kāi)始時(shí)觸發(fā)。

2、函數(shù)首先檢查瀏覽器是否支持語(yǔ)音合成服務(wù),如果不支持則輸出警告信息并返回。然后它檢查是否傳入了要轉(zhuǎn)換的文本內(nèi)容,如果沒(méi)有則直接返回。

3、接著,函數(shù)創(chuàng)建了一個(gè) SpeechSynthesisUtterance 對(duì)象,該對(duì)象表示一段要朗讀的文本。

4、然后將傳入的參數(shù)賦值給這個(gè)對(duì)象的相應(yīng)屬性,如文本內(nèi)容、語(yǔ)速、語(yǔ)言、音量和音調(diào)。

在設(shè)置好 SpeechSynthesisUtterance 對(duì)象的屬性后,

5、函數(shù)設(shè)置了兩個(gè)事件處理程序:onstart 和 onend。onstart 事件處理程序在語(yǔ)音播放開(kāi)始時(shí)觸發(fā) startEvent 回調(diào)函數(shù),onend 事件處理程序在語(yǔ)音播放結(jié)束時(shí)觸發(fā) endEvent 回調(diào)函數(shù)。

6、最后,函數(shù)通過(guò) speechSynthesis.speak() 方法來(lái)開(kāi)始語(yǔ)音合成,將 SpeechSynthesisUtterance 對(duì)象傳遞給該方法以開(kāi)始朗讀文本,并返回這個(gè) SpeechSynthesisUtterance 對(duì)象。

4、方法補(bǔ)充

下面小編為大家整理了一些其他js實(shí)現(xiàn)文字轉(zhuǎn)語(yǔ)音的方法,希望對(duì)大家有所幫助

1.還有Web Speech API

Web Speech API 是一個(gè)瀏覽器提供的用于語(yǔ)音識(shí)別和語(yǔ)音合成的API

包括 SpeechSynthesis語(yǔ)音合成 和 SpeechRecognition語(yǔ)音識(shí)別

https://developer.mozilla.org/zh-CN/docs/Web/API/SpeechSynthesis

實(shí)現(xiàn)代碼

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>語(yǔ)音合成功能</title>
</head>

<body>
    <h1>語(yǔ)音合成功能</h1>
    <textarea id="textToSpeak" rows="4" cols="50" placeholder="請(qǐng)輸入要朗讀的文本..."></textarea><br>
    <button id="speakButton">朗讀文本</button>

    <script>
        const textArea = document.getElementById("textToSpeak");
        const speakButton = document.getElementById("speakButton");

        // 檢查瀏覽器是否支持語(yǔ)音合成
        if (!window.speechSynthesis) {
            alert("您的瀏覽器不支持語(yǔ)音合成功能。");
        }

        // 獲取語(yǔ)音列表
        const voices = window.speechSynthesis.getVoices();
        // 朗讀文本
        speakButton.addEventListener("click", function () {
            const text = textArea.value.trim();
            if (text === "") {
                alert("請(qǐng)輸入文本內(nèi)容!");
                return;
            }
            console.log("開(kāi)始朗讀文本:", text);
            const utterance = new SpeechSynthesisUtterance(text);
            utterance.lang = "zh-CN"; // 設(shè)置語(yǔ)言為中文
            utterance.voice = voices.find(voice => voice.lang === "zh-CN"); // 選擇中文語(yǔ)音
            // 設(shè)置語(yǔ)速,取值范圍通常在 0.1 到 10 之間,這里設(shè)置為 0.8 倍速
            utterance.rate = 0.8;
            // 設(shè)置語(yǔ)調(diào),取值范圍一般在 0 到 2 之間,這里設(shè)為 1.5
            utterance.pitch = 1.5;
            // 設(shè)置音量,取值范圍從 0 到 1,這里設(shè)為 0.5
            utterance.volume = 0.5;
            // 監(jiān)聽(tīng)朗讀結(jié)束
            utterance.onend = function () {
                console.log("朗讀結(jié)束!");
            };

            // 開(kāi)始朗讀
            window.speechSynthesis.speak(utterance);
        });
    </script>
</body>

</html>

2.不調(diào)用第三方包

如果不想調(diào)用第三方的語(yǔ)音包,就可以用以下方法實(shí)現(xiàn),只不過(guò)原生API生成語(yǔ)音確實(shí)有點(diǎn)僵硬,isIe的方法是判斷當(dāng)前瀏覽器是否有ActiveXObject 對(duì)象,ActiveXObject 一般情況下是只有IE瀏覽器才有的,如果有就實(shí)例化一個(gè)對(duì)象,調(diào)用Speak方法就可以了;如果沒(méi)有就用SpeechSynthesisUtterance這個(gè)HTML5新增的API來(lái)操作。

具體代碼如下,在使用的地方直接調(diào)用playVoice()方法就可以了。

function isIe() {
    if (!!window.ActiveXObject || "ActiveXObject " in window) {
        return true
    } else {
        return false
    }
}
 
function playVoice() {
    let msg = '這是一個(gè)文字轉(zhuǎn)語(yǔ)音的demo'
    console.log(isIe())
    if (isIe()) {
        let voiceObj = new ActiveXObject("Sapi.SpVoice")
        voiceObj.Rate = -1
        voiceObj.Volume = 60
        voiceObj.Speak(msg, 1)
    } else {
        let speakMsg = new SpeechSynthesisUtterance(msg)
        speakMsg.rate = 1
        speakMsg.pitch = 1.5
        window.speechSynthesis.speak(speakMsg)
    }
 
}

以上就是原生JavaScript再網(wǎng)頁(yè)實(shí)現(xiàn)文本轉(zhuǎn)語(yǔ)音功能的詳細(xì)內(nèi)容,更多關(guān)于JavaScript文本轉(zhuǎn)語(yǔ)音的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript數(shù)據(jù)結(jié)構(gòu)中串的表示與應(yīng)用實(shí)例

    JavaScript數(shù)據(jù)結(jié)構(gòu)中串的表示與應(yīng)用實(shí)例

    這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)中串的表示與應(yīng)用,結(jié)合實(shí)例形式簡(jiǎn)單分析了基于javascript順序操作實(shí)現(xiàn)串結(jié)構(gòu)與串的拼接操作相關(guān)技巧,需要的朋友可以參考下
    2017-04-04
  • JavaScript實(shí)現(xiàn)獲取設(shè)備網(wǎng)絡(luò)連接信息

    JavaScript實(shí)現(xiàn)獲取設(shè)備網(wǎng)絡(luò)連接信息

    作為前端開(kāi)發(fā),做好用戶體驗(yàn)是很重要的,日常開(kāi)發(fā)中我們經(jīng)常可以遇到用戶網(wǎng)速慢導(dǎo)致靜態(tài)資源加載慢,從而給影響用戶體驗(yàn),所以本文來(lái)和大家分享一個(gè)有趣的API,可以實(shí)現(xiàn)獲取網(wǎng)絡(luò)信息
    2023-05-05
  • Nuxt.js 數(shù)據(jù)雙向綁定的實(shí)現(xiàn)

    Nuxt.js 數(shù)據(jù)雙向綁定的實(shí)現(xiàn)

    這篇文章主要介紹了Nuxt.js 數(shù)據(jù)雙向綁定的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • Vue 組件渲染詳情

    Vue 組件渲染詳情

    這篇文章主要介紹了Vue 組件渲染詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • 分享一些不常見(jiàn)卻很實(shí)用的JS技巧

    分享一些不常見(jiàn)卻很實(shí)用的JS技巧

    有些代碼,需要的時(shí)候能寫的出來(lái),但是也需要時(shí)間,如果有的東西長(zhǎng)時(shí)間不接觸,再次看的時(shí)候也會(huì)感覺(jué)很陌生,這篇文章主要給大家介紹了一些不常見(jiàn)卻很實(shí)用的JS技巧,既可以作為一個(gè)知識(shí)的積累,又可以作為閑暇時(shí)打發(fā)時(shí)間寫寫代碼的記錄,需要的朋友可以參考下
    2021-11-11
  • 原JS實(shí)現(xiàn)banner圖的常用功能

    原JS實(shí)現(xiàn)banner圖的常用功能

    這篇文章主要為大家詳細(xì)介紹了原JS實(shí)現(xiàn)banner圖的常用功能,,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 普通web整合quartz跑定時(shí)任務(wù)的示例

    普通web整合quartz跑定時(shí)任務(wù)的示例

    這篇文章主要介紹了普通web整合quartz跑定時(shí)任務(wù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • js實(shí)現(xiàn)可輸入可選擇的select下拉框

    js實(shí)現(xiàn)可輸入可選擇的select下拉框

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)可輸入可選擇的select下拉框,可及時(shí)匹配包含輸入的內(nèi)容,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • JS Promise axios 請(qǐng)求結(jié)果后面的.then() 是什么意思

    JS Promise axios 請(qǐng)求結(jié)果后面的.then() 是什么意思

    本文主要介紹了JS Promise axios 請(qǐng)求結(jié)果后面的 .then() 是什么意思,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • JSON字符串和對(duì)象相互轉(zhuǎn)換實(shí)例分析

    JSON字符串和對(duì)象相互轉(zhuǎn)換實(shí)例分析

    這篇文章主要介紹了JSON字符串和對(duì)象相互轉(zhuǎn)換的方法,結(jié)合實(shí)例形式分析了json格式數(shù)據(jù)的轉(zhuǎn)換方法,涉及javascript正則與字符串操作的相關(guān)技巧,需要的朋友可以參考下
    2016-06-06

最新評(píng)論