使用Jquery Ajax Ruby on Rails更新数据库

时间:2017-04-12 22:40:24

标签: jquery ruby-on-rails ajax database

我有一个列表项,其中包含我要编辑的名称。单击我的.editActivity按钮时,我使用Jquery更改列表项的名称,该列表项运行良好。我想使用Jquery的Ajax更新我的数据库中的名称。我觉得问题发生在我的activities_controller.rb或routes.rb但不确定。

  <ul class="list-group-sortable" id="Activities" >
<h1 align = "center">Activities</h1>

  <!-- List each activity in database -->
  <%  @activities.each do |activity| %>
    <li class="list-group-item" id="item" style="list-style: none;">

      <label class="my_label"><%= activity.a_name %></label>

      <!-- Edit activity -->
     <!-- link_to 'edit activity', edit_activity_path(activity) do %>-->
          <button class="editActivity" style="border:none; padding:0; background-color: transparent">
            <i class="fa fa-pencil fa-fw" aria-hidden="true" title="Edit" id="editActivity"></i>
          </button>
     <!-- end %>-->

    </li> <!-- End of list item -->
    <% end %> <!-- End of if statement -->
  <% end %> <!-- End of activity loop -->

这是我的Jquery用于更改名称和ajax:

  //Edit Activity
$('#Activities li .editActivity').click(function() {
    var name = $(this).closest('li').text();
    $('span').text("text is: " + name);
    var input = $('<input id="attribute" class="textbox" type="text" value="' + name + '" />')
    $(this).closest('li').append(input); 
    input.select(); 
    input.blur(function(event) {
        var text = $('input:text').val();
        $(event.target).closest('li').find('label').text(text);
        $('#attribute').remove(); //removes the newly created text box

            //ajax request to update database
        $(document).ajaxError(function(){
            alert("Error with AJAX call!");
            alert($(this).closest('li').attr('id'));
        });

        $.ajax({
            method: 'PUT',
            url: '/activities/' + id,
            data: { a_name: text}
        });

    });
});

这是我在activities_controller中的更新操作:

 def update
@activity = Activity.find(params[:id])
@activity.update_attributes(:a_name)
respond_to do |format|
  format.js {}
end

这是在我的routes.rb:

put '/activities/:id' => 'activities#update'

1 个答案:

答案 0 :(得分:0)

您的代码缺少headers来电中的ajax属性:

$.ajax({
  headers: {
    'X-CSRF-Token': $('meta[name="csrf-token"]').attr('content')
  },
  method: 'PUT',
  url: '/activities/' + id,
  data: { a_name: text }
});

您还需要为要呈现的update.js.erb操作创建update文件。

<强>更新

我还建议先更新您的数据库然后(如果更新成功)更改页面上项目的名称,只需将success属性添加到ajax调用:

$.ajax({
  headers: {
    'X-CSRF-Token': $('meta[name="csrf-token"]').attr('content')
  },
  method: 'PUT',
  url: '/activities/' + id,
  data: { a_name: text },
  success: function(response) {
    // update item name here
  }
});

response包含您在update.js.erb文件中添加的内容。