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

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

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

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

jQuery

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

Q&A

解決済

1回答

1933閲覧

jqueryが一瞬しか表示されない

awa

総合スコア34

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

jQuery

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

0グッド

0クリップ

投稿2019/02/17 15:05

編集2019/02/19 14:29

プルダウンで選択した値を、隣のテキストフォームに表示させたいのですが、
プルダウンから選択した一瞬だけしかフォームに表示されず、
すぐにフォームから消えてしまいます。
調べてみるとbuttonのtypeを指定していないためsubmit扱いとなり、一瞬しか表示されない、という記事はいくつか発見したのですが、今のコードではbuttonのtypeにbuttonを指定しているため原因がわからずにいます。
ご教示いただけませんでしょうか。

イメージ説明

ruby

1【ビュー】 2<div class="input-group" id="year"> 3 <span class="input-group-btn"> 4 <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false"> 56 <span class="caret"></span> 7 </button> 8 <ul class="dropdown-menu" role="menu"> 9 <li id="2017"><a href="#">2017</a></li> 10 <li id="2018"><a href="#">2018</a></li> 11 <li id="2019"><a href="#">2019</a></li> 12 </ul> 13 </span> 14 <input type="text" class="form-control" readonly> 15</div> 16 17<div class="input-group" id="month"> 18 <span class="input-group-btn"> 19 <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false"> 2021 <span class="caret"></span> 22 </button> 23 <ul class="dropdown-menu" role="menu"> 24 <% (1..12).each do |month| %> 25 <li id=<%= month %>><a href="#"><%= month %></a></li> 26 <% end %> 27 </ul> 28 </span> 29 <input type="text" class="form-control" readonly> 30</div>

jquery

1<script> 2$(function(){ 3 $("#month li").click(function () { 4 month = $(this).attr('id') 5 $("#month input").val(month); 6 }); 7 8 9 $("#year li").click(function () { 10 year = $(this).attr('id') 11 $("#year input").val(year); 12 13 14 $.ajax({ //ajax通信で以下のことを行います 15 url: '/approval_histories/search', //urlを指定 16 type: 'GET', //メソッドを指定 17 data: { 18 year: year, 19 month: month 20 }, 21 dataType: 'json' //データ形式を指定 22 }) 23 .done(function(data){ 24 $(data).each(function(i, approval_history){ 25 $('tbody').append('<tr>') 26 $('tbody tr').append('<td>' + approval_history.date + '</td>') 27 $('tbody tr').append('<td>' + approval_history.previous_in_at + '</td>') 28 $('tbody tr').append('<td>' + approval_history.previous_out_at + '</td>') 29 $('tbody tr').append('<td>' + approval_history.in_at + '</td>') 30 $('tbody tr').append('<td>' + approval_history.out_at + '</td>') 31 $('tbody tr').append('<td>' + approval_history.applying_attendance_change_target.name + '</td>') 32 $('tbody tr').append('<td>' + approval_history.created_at + '</td>') 33 $('tbody tr').append('<tr>') 34 }); 35 }) 36 }); 37}); 38</script>

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

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

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

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

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

x_x

2019/02/19 03:30

年のコードがダブってますが間違いですかね?
awa

2019/02/19 14:30

すみません、ダブって貼っていました。 重複しているコードを削除しました。
shinoharat

2019/02/20 03:00

li 要素の中にある a 要素を削除するとどうなりますか? <li id="2017"><a href="#">2017</a></li> ↓ <li id="2017">2017</li>
awa

2019/02/21 23:37

li要素の中のa要素を削除すると、一瞬ではなくちゃんと表示されるようになりました! ありがとうございます。 リンクをクリックしたことでリンク先に飛んだ扱いになっているのが原因でしょうか・・・。 ただリンクではなくなったことで、ホバー時の色変えやカーソルの変更などが無くなってしまったので、 こちらはCSSで頑張ります。 一度リロードしないとjQueryは動かない問題が発生しているので、 そちらはまた別の質問で投げようかなと思っております。
shinoharat

2019/02/26 04:08

おそらく turbolinks が原因なのだと思います。 以下の2つのうち、どちらかを試してみてください。 --------------------------------------------------------------- 【修正案1】turbolinks を off にする Gemfile 内の ↓ の行をコメントアウトする gem 'turbolinks' --------------------------------------------------------------- 【修正案2】turbolinks に対応した方法で jQuery を書き直す // 修正前 <script> $(function(){ $("#month li").click(function () { ...(中略)... }); }); </script> ↓  ↓  ↓ // 修正後 <script> $(document).on('turbolinks:load', function(){ $("#month li").click(function () { ...(中略)... }); }); </script> ---------------------------------------------------------------
awa

2019/03/02 05:14

修正案1で解決できました! ありがとうございます!
guest

回答1

0

自己解決

shinoharatさんの修正案1で解決できました

投稿2019/03/02 05:14

awa

総合スコア34

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問