未捕获的类型错误:SpeechRecognition 不是 app.js:5 中的构造函数

Mr.*_*rot 5 html javascript speech-recognition ecmascript-6

我正在编写语音识别助手以使其在我的网页中工作,但出现此错误:Uncaught TypeError: SpeechRecognition is not a constructor at app.js:5(我使用的是 Google Chrome 浏览器)。

const btn = document.querySelector('.talk');
const content = document.querySelector('.content');

const SpeechRecognition = window.SpeechRecognition || window.webkitSpeechrecognition;
const recognition = new SpeechRecognition(); 

recognition.onstart = function() {
   console.log('Voice Is Activated, You Can Speak');
};

recognition.onresult = function(event) {
   console.log(event);
};

btn.addEventListener('click', () => {
   recognition.start();
});
Run Code Online (Sandbox Code Playgroud)
<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>MY ASSISTANT</title>
   </head>
   <body>
      <h1>Hello World</h1>
      <img src="#" alt=""></img>
      <button class="talk">Talk</button>
      <h1 class="content"></h1>

      <script src="app.js"></script>
   </body>
</html>
Run Code Online (Sandbox Code Playgroud)

Jac*_*ord 5

您需要确保保持正确的大小写 - 它是webkitSpeechRecognition(大写R)。

const SpeechRecognition = window.speechRecognition || window.webkitSpeechRecognition;
console.log(new SpeechRecognition());
Run Code Online (Sandbox Code Playgroud)