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

由于Chrome从18年4月开始禁止音视频自动播放,导致语音合成在页面加载后无法自动播报。为解决此问题,可以尝试两种方案:一是将网址添加到浏览器的安全设置中允许声音;二是监听用户点击事件,确保用户有交互后再进行语音播报。若在iframe环境下,还需处理点击事件的传递和计数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原因

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

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

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

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

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

chrome://settings/content/sound

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值