当我在做一些事情时,我发现了一个奇怪的问题。我尝试进行语音识别。条件的第一部分正常工作,但不适用于第二部分。
var v;
function test() {
var ses = new webkitSpeechRecognition();
ses.lang = "En"
ses.continuous = true;
ses.start();
ses.onresult = function(event)
if (event.results.length > 0) {
sonuc = event.results[event.results.length - 1];
document.querySelector("input").value = sonuc[0].transcript;
v = sonuc[0].transcript;
console.log(v + " 1");
if (v == "good") {
switchLED('on');
console.log(v + "2");
console.log("OK !");
console.log("LED ok");
}
if (v == "bad") {
switchLED('off');
console.log(v + "2");
console.log("OK !");
console.log("LED off");
}
}
}
我第一次说:good
结果是:
good 1
good 2
OK !
LED OK
这是正确的。
然后,如果我第二次说:bad
结果是:
bad 1
它没有通过条件if(v == "bad")
。
bad
只有当我说第二个字时才会发生。如果我第一次刷新页面并直接说“不好”,我会得到所有正确的结果。