亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄 搜尋
導(dǎo)論 前言 為什么學(xué)習(xí)JavaScript JavaScript的歷史 基本語(yǔ)法 語(yǔ)法概述 數(shù)值 字符串 對(duì)象 數(shù)組 函數(shù) 運(yùn)算符 數(shù)據(jù)類型轉(zhuǎn)換 錯(cuò)誤處理機(jī)制 JavaScript 編程風(fēng)格 標(biāo)準(zhǔn)庫(kù) Object對(duì)象 包裝對(duì)象和Boolean對(duì)象 Number對(duì)象 String對(duì)象 Math對(duì)象 Date對(duì)象 RegExp對(duì)象 JSON對(duì)象 ArrayBuffer:類型化數(shù)組 面向?qū)ο缶幊?/a> 概述 封裝 繼承 模塊化編程 DOM Node節(jié)點(diǎn) document節(jié)點(diǎn) Element對(duì)象 Text節(jié)點(diǎn)和DocumentFragment節(jié)點(diǎn) Event對(duì)象 CSS操作 Mutation Observer 瀏覽器對(duì)象 瀏覽器的JavaScript引擎 定時(shí)器 window對(duì)象 history對(duì)象 Ajax 同域限制和window.postMessage方法 Web Storage:瀏覽器端數(shù)據(jù)儲(chǔ)存機(jī)制 IndexedDB:瀏覽器端數(shù)據(jù)庫(kù) Web Notifications API Performance API 移動(dòng)設(shè)備API HTML網(wǎng)頁(yè)元素 Canvas API SVG 圖像 表單 文件和二進(jìn)制數(shù)據(jù)的操作 Web Worker 服務(wù)器發(fā)送事件 Page Visibility API Fullscreen API:全屏操作 Web Speech requestAnimationFrame WebSocket WebRTC Web Components HTML網(wǎng)頁(yè)的API HTML網(wǎng)頁(yè)元素 Canvas API SVG 圖像 表單 文件和二進(jìn)制數(shù)據(jù)的操作 Web Worker 服務(wù)器發(fā)送事件 Page Visibility API Fullscreen API:全屏操作 Web Speech requestAnimationFrame WebSocket WebRTC Web Components 開(kāi)發(fā)工具 console對(duì)象 PhantomJS Bower:客戶端庫(kù)管理工具 Grunt:任務(wù)自動(dòng)管理工具 Gulp:任務(wù)自動(dòng)管理工具 Browserify:瀏覽器加載Node.js模塊 RequireJS和AMD規(guī)范 Source Map JavaScript 程序測(cè)試 JavaScript高級(jí)語(yǔ)法 Promise對(duì)象 有限狀態(tài)機(jī) MVC框架與Backbone.js 嚴(yán)格模式 ECMAScript 6 介紹 附錄 JavaScript API列表
文字

    • 概述

    • SpeechRecognition對(duì)象

    • 事件

    • 參考鏈接

概述

這個(gè)API用于瀏覽器接收語(yǔ)音輸入。

它最早是由Google提出的,目的是讓用戶直接進(jìn)行語(yǔ)音搜索,即對(duì)著麥克風(fēng)說(shuō)出你所要搜索的詞,搜索結(jié)果就自動(dòng)出現(xiàn)。Google首先部署的是input元素的speech屬性(加上瀏覽器前綴x-webkit)。

<input id="query" type="search" class="k-input k-textbox" 
 x-webkit-speech speech />

加上這個(gè)屬性以后,輸入框的右端會(huì)出現(xiàn)了一個(gè)麥克風(fēng)標(biāo)志,點(diǎn)擊該標(biāo)志,就會(huì)跳出語(yǔ)音輸入窗口。

由于這個(gè)操作過(guò)于簡(jiǎn)單,Google又在它的基礎(chǔ)上提出了Web Speech API,使得JavaScript可以操作語(yǔ)音輸入。

目前,只有Chrome瀏覽器支持該API。

SpeechRecognition對(duì)象

這個(gè)API部署在SpeechRecognition對(duì)象之上。

var SpeechRecognition = window.SpeechRecognition || 
                        window.webkitSpeechRecognition || 
                        window.mozSpeechRecognition || 
                        window.oSpeechRecognition || 
                        window.msSpeechRecognition;

為了將來(lái)的兼容性考慮,上面的代碼列出了所有瀏覽器的前綴。但是實(shí)際上,目前只有window.webkitSpeechRecognition是可用的。

確定瀏覽器支持以后,新建一個(gè)SpeechRecognition的實(shí)例對(duì)象。

if (SpeechRecognition) {       
  var recognition = new SpeechRecognition();
  recognition.maxAlternatives = 5;
}

maxAlternatives屬性等于5,表示最多返回5個(gè)語(yǔ)音匹配結(jié)果。

事件

目前,該API部署了11個(gè)事件。下面對(duì)其中的3個(gè)定義回調(diào)函數(shù)(假定speak是語(yǔ)音輸入框)。

var speak = $('#speak');

recognition.onaudiostart = function() {
  speak.val("Speak now...");
};

recognition.onnomatch = function() {
  speak.val("Try again please...");
};

recognition.onerror = function() {
  speak.val("Error. Try Again...");
};

首先,瀏覽器會(huì)詢問(wèn)用戶是否許可瀏覽器獲取麥克風(fēng)數(shù)據(jù)。如果用戶許可,就會(huì)觸發(fā)audiostart事件,準(zhǔn)備接收語(yǔ)音輸入。如果找不到與語(yǔ)音匹配的值,就會(huì)觸發(fā)nomatch事件;如果發(fā)生錯(cuò)誤,則會(huì)觸發(fā)error事件。

如果得到與語(yǔ)音匹配的值,則會(huì)觸發(fā)result事件。

recognition.onresult = function(event) { 

  if (event.results.length > 0) { 

    var results = event.results[0], 
        topResult = results[0];    if (topResult.confidence > 0.5) {
      speechSearch(results, topResult);
    } else {
      speak.val("Try again please...");
    }
  }
};

result事件回調(diào)函數(shù)的參數(shù),是一個(gè)SpeechRecognitionEvent對(duì)象。它的results屬性就是語(yǔ)音匹配的結(jié)果,是一個(gè)數(shù)組,按照匹配度排序,最匹配的結(jié)果排在第一位。該數(shù)組的每一個(gè)成員是SpeechRecognitionResult對(duì)象,該對(duì)象的transcript屬性是實(shí)際匹配的文本,confidence屬性是可信度(在0與1之間)。

參考鏈接


上一篇: 下一篇: