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

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

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

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

5029閲覧

jQuery メニューアイテムの選択をする処理

questioner55

総合スコア90

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2015/01/18 14:09

編集2015/02/18 03:48

メニューからアイテムが選択されたらフォームを送るようにしたいです。検索フォームでクラスを設定し、イベントセレクトを使っています。参照:http://docs.jquery.com/UI/Autocomplete#event-select

キーボードを使ってアイテムを選ぶと機能します。しかし、マウスを使って選択しようとすると、事前にタイプされた値をだします。

送信のために使っているコードです:

$("#searchform-input").autocomplete({
select: function (a, b) {
$(".searchform1").submit()
}
});

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

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

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

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

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

guest

回答1

0

ベストアンサー

これは、イベントハンドラの実行終了後に、selectイベントのデフォルトの挙動が実行されているからです。(そのため、選択したらキャンセルできます)

https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.autocomplete.js#L241

ということは、何かをクリックしたときに、ウィジェットがinputを埋める前にフォームは送信されます。

以下で直せるかと思います:

$("#searchform-input").autocomplete({
select: function (a, b) {
$(this).val(b.item.value);
$(".searchform1").submit()
}
});

さて、おそらく、なぜキーボードを使うときにこうなるのか?と不思議に思っているかもしれません。

これは、focusイベントが、inputないでフォーカスされたアイテムをポピュレートするからです。(inputはリストを上下に動かすことによってポピュレートされます。)アイテムにマウスオーバーすると、focusイベントが呼び出され、inputをポピュレートします。focusイベントが原因で、enterキーを使って選択すると、正しい値がinputに入ります。

投稿2015/01/18 15:05

編集2015/02/18 03:49
kodama_h

総合スコア28

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問