$.getJSON を呼び出すときに、tbody 要素をリロードしたい。つまり、すべての要素を削除し、Json 応答で新しい要素を配置する必要があります。
JS
$(document).ready(function(){
$('#position').sortable({
update: function(event, ui) {
var newOrder = $(this).sortable('toArray').toString();
$.getJSON('/save_positions.json', {ids:newOrder}, function(data){
??????
});
}
});
});
私の見解
# index.html.erb
<tbody id="position">
<%= render :partial => "activities"%>
</tbody>
部分図
#_activities.html.erb
<% @activities.each do |activity| %>
<tr id='<%= activity.id %>'>
<td><%= activity.position %></td>
<td><%= link_to activity.id, activity_path(activity) %></td>
<td><%= activity.name %></td>
<td><%= activity.estimated %></td>
<td><%= activity.used %></td>
<td><%=l activity.created_at %></td>
</tr>
マイ アクション (アプリケーション コントローラー)
def save_positions
@activities = Activity.all(:order => 'position')
respond_to do |format|
format.json { render :json => @activities }
end
end