2016-12-31 3 views
0

Я новичок в рубине, но кажется, что если у меня есть коллекция вещей, я должен быть в состоянии отображать их либо в цикле, либо в by defining a :collection.Могу ли я сделать эту коллекцию без использования .each()?

Здесь каждый сад может иметь множество растений, назначенных ему. У меня есть частичное, которое отображает растения в макете «карта». Эта точка зрения правильно делает растения для каждого сада:

просмотров/сады/show.html.haml

.row.plant-cards 
    - @garden.plants.each do |plant| 
    = render("shared/plants/card", {plant: plant, garden: @garden}) 

просмотров/общие/растения/_card.html.haml

.col-md-2 
    .plant.thumbnail.text-center 
    = button_to("+", add_to_garden_path(plant, @garden.id), {method: :post ,remote: true}) 
    = link_to(plant) do 
     = image_tag("http://lorempixel.com/g/150/150/food/",:alt => plant.name) 
     %h4.plant__title.caption= plant.name 

Я пытаюсь обновить предоставленные растения на странице сада через ajax. Похоже, что мне нужно придерживаться вывода рендерных «карт» в функции .html(), и использование .each() кажется неуклюжим для этого. Похоже, что я должен быть в состоянии установить растения как :collection, что я пытаюсь сделать ниже, но это не работает:

просмотров/растения/add_to_garden.js.erb (извините для смешивания Haml/ERB - Я изучаю это тоже)

<% flash.each do |key, message| %> 
    $("#flash").html("<%= j render partial: "shared/flash_message", locals: {key: key, message: message } %>"); 
<% end %> 
$(".plant-cards").html("<%= j render :partial => 'shared/plants/card', :collection => @garden.plants, :locals => {garden: @garden} %>"); 

Когда я сделать Ajax вызов моего приложения я получаю эту ошибку во время выполнения:

Started POST "/plants/2/add_to_garden/1" for ::1 at 2016-12-30 20:32:18 -0500 
Processing by PlantsController#add_to_garden as JS 
    Parameters: {"authenticity_token"=>"qJU/CEZudZFP9l6r1qdAlXJQrfY7fB0aZHmjRJh2yQO0IzxilP47mP2UjDDAmBNJouFtoAWkv/hJ2gCNR5BpgQ==", "id"=>"2", "garden_id"=>"1"} 
    Garden Load (0.3ms) SELECT `gardens`.* FROM `gardens` WHERE `gardens`.`id` = 1 LIMIT 1 
    Plant Load (0.2ms) SELECT `plants`.* FROM `plants` WHERE `plants`.`id` = 2 LIMIT 1 
    (0.1ms) BEGIN 
    SQL (0.2ms) INSERT INTO `gardens_plants` (`garden_id`, `plant_id`) VALUES (1, 2) 
    (160.8ms) COMMIT 
    (0.2ms) BEGIN 
    User Load (0.3ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 LIMIT 1 
    (0.1ms) COMMIT 
    Rendered shared/_flash_message.html.erb (0.3ms) 
    Plant Load (0.5ms) SELECT `plants`.* FROM `plants` INNER JOIN `gardens_plants` ON `plants`.`id` = `gardens_plants`.`plant_id` WHERE `gardens_plants`.`garden_id` = 1 
    Rendered shared/plants/_card.html.haml (29.7ms) 
    Rendered plants/add_to_garden.js.erb (42.3ms) 
Completed 500 Internal Server Error in 238ms (ActiveRecord: 162.9ms) 

NameError - undefined local variable or method `plant' for #<#<Class:0x007fdf9be0f6c8>:0x007fdf9bce6350>: 
    app/views/shared/plants/_card.html.haml:3:in `_app_views_shared_plants__card_html_haml___4163891484537289381_70299132319600' 
    ... 
+0

В рельсах существует множество способов сделать что-то. Ваш подход к интерполяции html в javascript не нужен. Вы можете так же легко поместить html в скрытый узел и ссылаться на него с помощью javascript, используя id –

+1

Попробуйте использовать вот так: '<% = j render partial: 'shared/plants/card', collection: @ garden.plants, as: : plant, locals: {garden: @garden}%> ' – Deep

+0

@Deep - Да! Отлично. Я забыл, что вы можете указать коллекцию 'как:' что-то, но это была проблема, с которой я крутился - спасибо. – doub1ejack

ответ

0

Просто поставить @ ответ Deep в в вопрос, он предложил

Try using like this: <%= j render partial: 'shared/plants/card', collection: @garden.plants, as: :plant, locals: { garden: @garden } %>

Указание сбора @ garden.plants, как :plant сделал трюк.

Смежные вопросы