プルダウンで選択した値を、隣のテキストフォームに表示させたいのですが、
プルダウンから選択した一瞬だけしかフォームに表示されず、
すぐにフォームから消えてしまいます。
調べてみると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"> 5 年 6 <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"> 20 月 21 <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>
回答1件
あなたの回答
tips
プレビュー