Я застрял хуже, чем Юго в канаве.
Я добавил изменения, которые в итоге сделали эту работу ниже (помечены жирным шрифтом правки ).
Фон
- Виджеты имеют много Гаджетов
- Последний столбец td в таблице имеет
check_box_tags
для выбора отдельных записей гаджетов для удаления
Желаемое поведение
- Пользователь должен иметь возможность нажимать «checkall», а также отдельные флажки, чтобы выбирать гаджеты по одному
- Нажатие кнопки «Удалить выбранное» должно удалить отмеченные записи без обновления страницы
РЕДАКТИРОВАТЬ: Добавление более подробной информации о том, что не работает
Наблюдаемое поведение
- метод destroy_multiple в gadgets_controller.rb никогда не вызывается
вместо этого, кажется, вызывается метод create
Started POST "/widgets/1/gadgets" ...
Processing by GadgetsController#create as JS
Parameters: {"utf8"=>"✓", "authenticity_token"=>"...=", "widget"=>{"gadget_ids"=>["all", "140", "139"]}, "widget_id"=>"1"}
Widget Load (0.3ms) SELECT "widgets".* FROM "widget" WHERE "widget"."id" = $1 LIMIT 1 [["id", "1"]]
Rendered gadgets/create.html.haml within layouts/application (1.1ms)
Rendered layouts/_header.html.haml (0.2ms)
Completed 200 OK in 36ms (Views: 19.0ms | ActiveRecord: 5.0ms)
Мне тоже неясно по этому поводу: {"gadget_ids"=>["all", "140", "139"]}
.
"all" - это идентификатор css id 1, используемый для "checkall". В приведенном ниже файле checkbox.js.coffee я пытаюсь удалить значение «all» из массива с помощью javascript. Когда я записываю массив в консоль, «все» удаляется успешно. И все же он продолжает отправляться на контроллер гаджетов.
EDIT Удаленная форма rails заполняет массив гаджетов для запроса POST. просто нужно было правильно его настроить.
Модель
widget.rb
class Widget < ActiveRecord::Base
has_many :gadgets
validates_presence_of :name
end
gadget.rb
class Gadget < ActiveRecord::Base
belongs_to :widget
validates_presence_of :widget_id
end
Контроллер гаджетов
class GadgetsController < ApplicationController
include ApplicationHelper
before_filter :get_widget
before_filter :widget_gadgets, only: [ :index ]
respond_to :json
def json_widgets
[ @widget, @gadgets ]
end
def index
respond_with(json_widgets) do |format|
format.json
format.html
end
end
def new
@gadget = @widget.gadgets.new()
end
def create
@gadget=@widget.gadgets.new(params[:gadget])
if @gadget.save
flash[:success] = "Gadget was successfully created"
redirect_to widget_gadgets_path
end
end
def destroy_multiple
gadget_ids=(params[:gadget_ids])
to_delete=[]
gadget_ids.split(',').each do |gadget_id|
to_delete.push(Gadget.find(gadget_id))
end
to_delete.each do |del|
del.destroy()
end
flash.now[:success] = "Gadget Destroyed Successfully"
respond_to do |format|
format.html { redirect_to widget_gadgets_path(@widget) }
format.json { render :json => to_delete.to_json }
end
end
def destroy
@gadget = gadget.find(params[:gadget_id])
@widget.gadgets.destroy(@gadget.id)
respond_to do |format|
format.html { redirect_to(widget_gadgets_path) }
end
end
def get_widget
begin
@widget = Widget.find(params[:widget_id])
rescue ActiveRecord::RecordNotFound
render file: "public/404.html", status: 404
end
end
private
def widget_gadgets
@widget=Widget.find(params[:widget_id])
@gadgets=@widget.gadgets unless @widget.gadgets.nil?
end
end
routes.rb
Я пытаюсь использовать блок collection do . Это правильный способ реализации маршрута destroy_multiple?
DestroyMultiple::Application.routes.draw do
resources :widgets
resources :gadgets, :only => [ :new, :create ]
resources :widgets do
resources :gadgets do
collection do
post :destroy_multiple
end
end
end
match "/:id" => 'widget#gadgets'
root to: 'widgets#index'
end