HTML、CSS 和 JavaScript 在线文本到语音转换
HTML、CSS 和 JavaScript 在线文本到语音转换
HTML:
<main>
<h1 class="title">文字转语音</h1>
<div class="text-section">
<p class="text-input">输入文字</p>
<textarea name="" id="text">
</textarea>
</div>
<div class="text-voice">
<p class="text-voice-text">选择语音</p>
<select name="" id="voice">
<option value="Google US English">谷歌美国英语</option>
</select>
</div>
<button class="submit">转换为语音</button> </main>
CSS:
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,[[email protected]](/cdn-cgi/l/email-protection),300;0,400;0,700;1,300&display=swap'); *{
font-family: 'Roboto Condensed', sans-serif;
box-sizing:边框框;
边距:0;
填充:0; } 身体{
显示:弯曲;
证明内容:中心;
对齐项目:居中;
高度:100vh;
背景颜色:#D6EFED;
} 主要的{
背景颜色:#4FDBBA;
高度:27rem;
宽度:23rem;
边界半径:1.25rem;
盒子阴影:rgba(0, 0, 0, 0.07) 0px 1px 2px, rgba(0, 0, 0, 0.07) 0px 2px 4px, rgba(0, 0, 0, 0.07) 0px 4px 8px, rgba(0, 0, 0, 0.07) 0px 8px 16px, rgba(0, 0, 0, 0.07) 0px 16px 32px, rgba(0, 0, 0, 0.07) 0px 32px 64px;
显示:弯曲;
justify-content:空间均匀;
对齐项目:居中;
弹性方向:列; } 。标题{
字体大小:2rem;
字体粗细:粗体;
颜色:#072227;
文字阴影:1px 1px 1px #010;
} .文本部分{
显示:弯曲;
证明内容:中心;
对齐项目:居中;
弹性方向:列;
间隙:5px;
} .文本输入{
白颜色;
对齐自我:开始;
字体粗细:粗体;
} #文本{
高度:5rem;
宽度:18rem;
边界半径:0.5rem;
盒子阴影:rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
边框:无;
调整大小:无;
字体大小:.85rem;
填充:8px 10px;
轮廓:2px 实心 rgba(120, 120, 120, 0.623);
} .文本语音{
显示:弯曲;
证明内容:中心;
对齐项目:居中;
弹性方向:列;
} .text-voice-text{
字体粗细:粗体;
白颜色;
对齐自我:开始;
边距底部:1rem; } #嗓音{
高度:2rem;
宽度:18rem;
盒子阴影:rgb(38, 57, 77) 0px 20px 30px -10px;
边界半径:0.35rem;
填充:0px 10px;
轮廓:2px 实心 rgba(120, 120, 120, 0.623);
} 按钮{
背景颜色:#072227;
白颜色;
高度:2.5rem;
宽度:18rem;
边界半径:0.5rem;
保证金:1rem;
边框:无;
字体大小:1rem;
字体粗细:粗体;
盒子阴影:rgba(0, 0, 0, 0.3) 0px 19px 38px, rgba(0, 0, 0, 0.22) 0px 15px 12px; } @media(最大宽度:700px){
主要的 {
宽度:60vw;
} #文本{
宽度:10rem;
} #嗓音{
宽度:10rem;
} 按钮{
宽度:10rem;
}
}
JavaScript:
const textarea = document.querySelector('#text')
让 voicelist = document.querySelector('#voice')
让 Speechbtn = document.querySelector('.submit') 让 synth = SpeechSynthesis
让 isSpeaking = true 功能语音(){
for (让 synth.getVoices() 的声音) {
let option = document.createElement('option')
option.text = voice.name
voicelist.add(选项)
console.log(选项)
}
} synth.addEventListener('voiceschanged', voicespeech) 功能文本语音(文本){
让 utterance = new SpeechSynthesisUtterance(text)
for (让 synth.getVoices() 的声音) {
if (voice.name === voicelist.value) {
utterance.voice = 声音
}
}
SpeechSynthesis.speak(话语)
} //
Speechbtn.addEventListener('click', (e) => {
e.preventDefault()
if (textarea.value != '') {
如果(!synth.speaking){
texttospeech(textarea.value)
}
if (textarea.value.length > 80) {
如果(说话){
合成器.resume()
isSpeaking = 假
Speechbtn.innerHTML = '暂停语音'
} 别的 {
合成器.pause()
isSpeaking = 真
Speechbtn.innerHTML = '恢复演讲'
}
setInterval(() => {
if (!synth.speaking && !isSpeaking) {
isSpeaking = 真
Speechbtn.innerHTML = '转换为语音'
}
})
} 别的 {
Speechbtn.innerHTML = '转换为语音'
}
}
})
语音()
HTML、CSS 和 JavaScript 代码片段开启, AllWebCodes.com
完毕!享受 文字转语音片段
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通