質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

Q&A

解決済

1回答

483閲覧

Web Speech APIで音声認識して入力された文字列を元に、autocomplete(jQuery UI)を展開させたい

k.t.est

総合スコア49

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

0グッド

0クリップ

投稿2020/03/16 00:55

Web Speech API の SpeechRecognitionで、認識した音声データの文字列をinputタグに登録し、その文字列の内容を元にjQuery UIのautocompleteを展開したいのですが、展開されません。
(inputタグに文字列が入力されるのみです。なお、何らかの文字列を入力すると、autocompleteは展開されます。)

jQuery UIのautocompleteの説明書き(https://api.jqueryui.com/autocomplete/)を読むと、「When typing in the autocomplete field, the plugin starts searching....」と記載されており、autocompleteのフィールドに何らかのタイピングが必要とも取れるのですが、タイピングなしにautocompleteを展開することは出来ないのでしょうか?

ご教示頂ければ幸甚で御座います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決できたので、方法下記致します。

まず、autocompleteのフィールドにフォーカスが当たると、autocompleteが展開されるようにしておきます。

javascript

1//① autocompleteにbindを付けて、フォーカスが当たると検索されるようにする。 2function auto_comp(){ 3 $(....).autocomplete({ 4 //autocompleteの内容 5 ..... 6 }).bind("focus",function(){ 7 $(this).autocomplete("search"); 8 }); 9}

次にSpeechRecognitionで、継続的に音を取らずに毎回終わるように設定し、
認証終了時に、上記関数を呼び出して、入力欄にフォーカスが当たるようにする。

javascript

1SpeechRecognition = webkitSpeechRecognition || SpeechRecognition; 2recognition = new SpeechRecognition(); 3recognition.continuous = false; 4 5recognition.onresult = (event) => { 6 //入力欄に音声結果を入れる 7} 8 9recognition.onend = () => { 10 //autocompleteをバインド 11 auto_comp(); 12 13 //フォーカスを当てて、autocompleteを動かす。 14 $("入力欄").trigger("focus"); 15} 16

これでtrigger()でフォーカスが当たると、autocompleteが展開されると思います。

投稿2020/03/17 01:11

k.t.est

総合スコア49

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問