window.speechSynthesis语音合成在chrome浏览器中刷新无法自动播报

原因

chrome浏览器在18年4月起,就在桌面浏览器全面禁止了音视频的自动播放功能。

严格地来说,是Chrome不允许在用户对网页进行触发之前播放音频。

在页面加载完毕的情况下,用户需要有主动交互行为,才能正常播放。

解决方案一:在浏览器安全设置中添加网址

在浏览器安全设置中将需要播放语音的网址加进去

chrome://settings/content/sound

添加网址,刷新或重新加载就会自动播报

解决方案二:监听用户点击事件

本来的想法是,页面加载好,弹出窗口,让用户点击后开启,但是领导觉得每次进来让用户点,体验不好,说用户进来肯定会点击界面,只要他点了,就给他开启,那就听领导的吧

页面中使用了iframe嵌套,会出现iframe点击 和 index页面点击,所以我定义了一个变量,接收窗口点击的次数

let windowClickCount = 0;

在iframe中,监听点击,发送消息

$("body").one("click", function () {
    window.parent.postMessage("点击了",'*');
});

index页面中监听

window.addEventListener('message',function(e){
    if (windowClickCount === 0) {
        initVoice(); // 调用语音播报
    }
    windowClickCount++;
},false);

// 监听body的点击事件
$("body").one("click", function (e) {
    if (windowClickCount === 0) {
        initVoice();
    }
    windowClickCount++;
});

如有更好的解决方案,欢迎指导

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果`window.speechSynthesis`有时无法播放文本,可能是由于以下原因: 1. 浏览器不支持Web Speech API:请确保您的浏览器支持Web Speech API。Web Speech API在某些旧版本的浏览器可能不可用。您可以在浏览器控制台检查是否有任何错误消息来确定问题的原因。 2. 合成语音数据未加载:有时浏览器可能需要更多时间来加载合成语音数据。您可以尝试等待片刻或尝试在`onvoiceschanged`事件更新可用的语音。例如: ```javascript const synth = window.speechSynthesis; let voices = []; synth.onvoiceschanged = () => { voices = synth.getVoices(); } const utterance = new SpeechSynthesisUtterance(this.text); utterance.voice = voices[0]; // 设置第一个可用的语音 synth.speak(utterance); ``` 3. 某些语音不可用:某些语音可能不可用或需要下载。您可以使用`synth.getVoices()`方法检查可用的语音,并选择一个可用的语音。例如: ```javascript const synth = window.speechSynthesis; let voices = []; synth.onvoiceschanged = () => { voices = synth.getVoices(); } const utterance = new SpeechSynthesisUtterance(this.text); const voice = voices.find(v => v.lang === 'en-US'); // 查找英语语音 utterance.voice = voice; synth.speak(utterance); ``` 4. 播放速率过快或过慢:有时语音播放速度可能会影响语音的可听性。您可以尝试调整播放速率。例如: ```javascript const synth = window.speechSynthesis; const utterance = new SpeechSynthesisUtterance(this.text); utterance.rate = 0.8; // 设置播放速率为0.8倍 synth.speak(utterance); ``` 希望这些提示可以帮助您解决问题。如果问题仍然存在,请提供更多详细信息,以便我更好地帮助您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值