3

我想使用Web Speech API大声说出一系列单词。

单词是一、二、三、四、五

在 Chrome 上说单词时,下面的脚本说第一个单词,然后重复最后一个单词,直到迭代完成,语音输出为:

一,五,五,五,五

在 Firefox 上,脚本说出第一个单词然后停止,语音输出为:

我已经将事情记录到控制台以试图弄清楚发生了什么,这是两个浏览器的结果。

word: one
message: one 
word: two 
message: two 
word: three 
message: three 
word: four 
message: four 
word: five 
message: five

控制台的输出是所需的语音输出,所以我不确定到底发生了什么。

var msg = new SpeechSynthesisUtterance();
var words = ['one', 'two', 'three', 'four', 'five'];

for (var i = 0; i < words.length; i++) {
    msg.text = words[i];

    console.log('word: ' + words[i]);
    console.log('message: ' + msg.text);

    window.speechSynthesis.speak(msg);
}

什么可能导致这种情况,我该如何纠正它?

4

1 回答 1

5

SpeechSynthesisUtterance您每次都需要使用一个新实例。

var words = ['one', 'two', 'three', 'four', 'five'];

for (var i = 0; i < words.length; i++) {
    var msg = new SpeechSynthesisUtterance();
    msg.text = words[i];

    console.log('word: ' + words[i]);
    console.log('message: ' + msg.text);

    window.speechSynthesis.speak(msg);
}

语音不会在零时间内播放,并且似乎后续SpeechSynthesisUtterance实例被放置在队列中,直到前一个语音完成播放。您重复使用同一个实例,在它们被排队之后speak(...)但在它们被从队列中弹出并读取之前修改它们。第一个话语(“one”)被正确播放,因为队列中没有其他东西可以阻止它(它会立即读取),但其余的需要等待,并且在被读取之前最终被修改。

于 2016-03-15T17:39:01.803 回答