質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1004閲覧

cocoonによる動的フォーム追加で追加ボタンを押すまで行が無い状態にしたい

07290729

総合スコア15

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/10/12 07:53

編集2018/10/13 18:34

Railsで、cocoonを使った動的なフォーム追加を実装しているのですが、
以下の画面の際に

イメージ説明

最初は空欄の行は表示されず、+ボタンが押された場合だけ
行が追加されるようにするにはどのようにすればよいでしょうか。
ご教授いただければ幸いです。

以下がフォーム追加の箇所になります。

  • app/views/targetservers/_form.html.erb
<%= form_with(model: targetserver, local: true) do |f| %> <% if targetserver.errors.any? %> <div id="error_explanation"> <h2><%= pluralize(targetserver.errors.count, "error") %> prohibited this targetserver from being saved:</h2> <ul> <% targetserver.errors.full_messages.each do |message| %> <li><%= message %></li> <% end %> </ul> </div> <% end %> <table> <tr> <td><%= f.label :os, "OS" %></td> <td><%= f.text_field :os, id: :targetserver_os %></td> </tr> <tr> <td><%= f.label :hostname %></td> <td><%= f.text_field :hostname, id: :targetserver_hostname %></td> </tr> <tr> <td><%= f.label :cpumemory, "CPU & Memory" %></td> <td><%= f.text_field :cpumemory, id: :targetserver_cpumemory %></td> </tr> <tbody id="disks"> <tr> <td>partition name</td> <td>size</td> </tr> <tr> <td><%= f.text_field :partitionname, value: "/" %></td> <td><%= f.text_field :size, value: "30" %></td> <td><%= link_to_add_association '+', f, :disks, class: 'btn btn-default', data: { association_insertion_node: '#disks', association_insertion_method: 'append' } %></td> </tr> <%= f.fields_for :disks do |dk| %> <%= render 'disk_fields', f: dk %> <% end %> </tbody> </table> <div class="actions"> <%= f.submit %> </div> <% end %>
  • app/views/targetservers/_disk_fields.html.erb
<tr class="nested-fields"> <td><%= f.text_field :partitionname, value: "" %></td> <td><%= f.text_field :size, value: "" %></td> <td><%= link_to_remove_association "-", f, class: 'btn btn-default' %></td> </tr>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

controllerってどんな感じですか?
自分も同じところでハマってましたが
def newのxx.buildを消したら出来ました。
今回のケースだともし
@targetserver.disks.build
がある場合、消したら行けるかもしれないです。

投稿2018/10/22 14:00

GoToWorks

総合スコア74

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

07290729

2018/10/23 00:10

ご指摘いただいた内容で ---- class TargetserversController < ApplicationController before_action :set_targetserver, only: [:show, :edit, :update, :destroy] # GET /targetservers # GET /targetservers.json def index @targetservers = Targetserver.all end # GET /targetservers/1 # GET /targetservers/1.json def show end # GET /targetservers/new def new @targetserver = Targetserver.new #@targetserver.disks.build end # GET /targetservers/1/edit def edit end ---- まさに、該当箇所をコメントアウトしたらいけました! 大変助かりました! ありがとうございますmm
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問