4

我在我的移动网站中使用 SpeechSynthesisUtterance。当我在桌面版网站中使用此代码时,它是可以的。但我发现该功能在 document.ready 中的移动浏览器中不起作用,如下所示:

 $(document).ready(function(){
 var text_tts="say something";
 speakText(text_tts);
    });
function speakText(text_tts){
var u = new SpeechSynthesisUtterance();
u.text = text_tts;
u.lang = 'en-US';
u.rate = 1;
u.onend = function(event) { console.log('Finished in ' + event.elapsedTime + ' seconds.'); }
speechSynthesis.speak(u);

}

但是当我使用“点击”事件时,它会起作用:

$("body").on("click",".button",function(){
         var tmp_body_text="say something";
                   var u = new SpeechSynthesisUtterance();
                   u.text = tmp_body_text;
                   u.lang = 'en-US';
                   u.rate = 1;
                   //u.onend = function(event) { console.log('Finished in ' + event.elapsedTime + ' seconds.'); }
                   speechSynthesis.speak(u);
                   });

请帮忙。谢谢你。

4

1 回答 1

2

我已经看到了一些仅在从用户交互(例如单击)调用时才有效的提及(例如this) 。speak据我所见,iOS 上的 Safari 似乎就是这种情况,这似乎就是您在问题中所描述的。

我实际上还没有找到任何证实这种行为的文档,并且希望任何人都可以提供任何参考。

于 2015-03-02T21:44:30.987 回答