0

当我说出一个句子时,我尝试用我的程序来识别一个特定的单词,它使用 Web 语音 API。

当我单独说出这个词时,我的程序工作正常,但是当我在一个句子中说出它时,我的程序无法运行。

谢谢告诉我我的程序的问题在哪里。

<script>
    (function($)
    {
        var $btn = $('#btn');
        var $result = $('#result');
        var words = null;
        if ('webkitSpeechRecognition' in window)
        {
            var recognition = new webkitSpeechRecognition();
            recognition.lang = "fr-FR";
            recognition.continuous = false;
            recognition.interimResults = true;
            $btn.click(function(e)
            {
                e.preventDefault();
                $btn.removeClass('btn-primary');
                recognition.start();
            });
            recognition.onresult = function (event)
            {
                $result.text('');
                for (var i = event.resultIndex; i < event.results.length; i++)
                {
                    var transcript = event.results[i][0].transcript;
                    if (event.results[i].isFinal)
                    {
                        $result.text(transcript);
                        recognition.stop();
                        $btn.addClass('btn-primary');
                        words = transcript.split(' ');
                        if(words[0] == 'test')
                        {
                            // do something                   
                        }
                        return true;
                    }
                    else
                    {
                        $result.text($('#result').text() + event.results[i][0].transcript);
                    }
                }
            };
        }
        else{$btn.hide();}
    })(jQuery);
</script>
4

1 回答 1

0

当您这样做时,words = transcript.split(' ')您将单词设置为所有已识别单词的数组。然后,当您这样做时,if(words[0] == 'test')您只检查第一个单词,因此只有当您尝试识别的单词是第一个(或唯一一个)单词时,它才会起作用。

而不是这个:

if(words[0] == 'test')
{
    // do something
}

尝试这个:

words.some(function (word) {
    if (word === 'test') {

        // do something

        return true;
    }
});
于 2016-02-04T10:57:35.470 回答