11

私はアプリ作成の初期段階にあり、基本的なコードを配置しているところです。これが現在のコードです...

アプリ/ビュー/カード/front.html.erb

<%= form_for(front_of_card_path) do |f| %>
  <%= f.fields_for :competency_templates do |builder| %>
    <%= render 'add_fields', f: builder %>
  <% end %>
  <%= link_to_add_fields "Add New Tag", f, :skill %>
<% end %>

ルート

 controller :cards do
    get  '/front',            action: 'front',  as: 'front_of_card'
    post '/save',             action: 'create', as: 'save_card'
    get  '/my_contact_info',  action: 'back',   as: 'back_of_card'
    put  '/save',             action: 'update', as: 'save_card'
    get  '/my_card',          action: 'show',   as: 'card'
  end

コントローラ

  def create
    @skill= Skill.new(params[:skill])
    @tag = Tag.new(params[:tag])
    @tag.save
    @skill.tag_id = @tag.id
    @skill.save
    redirect_to front_of_card_path, notice: 'Skill was successfully created.'
    #get user/session
    #save skills & tags
  end

cards.js.コーヒー

jQuery ->
  $('form').on 'click', '.remove_fields', (event) ->
    $(this).prev('input[type=hidden]').val('1')
    $(this).closest('fieldset').hide()
    event.preventDefault()

  $('form').on 'click', '.add_fields', (event) ->
    time = new Date().getTime()
    regexp = new RegExp($(this).data('id'), 'g')
    $(this).before($(this).data('fields').replace(regexp, time))
    event.preventDefault()

app_helper

module ApplicationHelper
  def link_to_add_fields(name, f, association)
    new_object = f.object.send(association).klass.new
    id = new_object.object_id
    fields = f.fields_for(association, new_object, child_index: id) do |builder|
      render(association.to_s.singularize + "_fields", f: builder)
    end
    link_to(name, '#', class: "add_fields", data: {id: id, fields: fields.gsub("\n", "")})
  end
end

したがって、現在、このコードは 2 つのテキスト フィールドを提供しています。1 つはタグ名用、もう 1 つはタグの重み用で、コントローラーはすべてを DB に挿入します。JavaScript を使用して、これらのタグ/重みフィールドを好きなだけ動的に追加したいと思います。私が見つけたものはすべて、ネストされた属性に焦点を当てているようです。どんなアイデアでも大歓迎です。

アップデート

これを具体化するためにさらにコードを追加しました。私が抱えている問題は、この行で渡す 3 番目の変数です...

  <%= link_to_add_fields "Add New Tag", f, :skill %>

「:skill」は好きではありませんが、ここで何を渡す必要があるのか​​ わかりません。

4

1 に答える 1

27

これが私が思いついたものです...ここに私の2つのモデルがあります...

class Skill < ActiveRecord::Base
  belongs_to :tag
  attr_accessible :tag_id, :weight
end

class Tag < ActiveRecord::Base
  has_many :skills
  attr_accessible :name
end

app/views/skills/_form.html.erb からパーシャルを呼び出し、js タグを使用して新しいフィールドを追加しています。また、パーシャルを再レンダリングしてから、最後の div タグに隠していることにも注意してください。

  <div id="skillSet">
    <%= render partial: "skills_form" %>

  </div>
  <a href="javascript:;" id="addNewTag">Add New Tag</a>

  <div class="actions">
    <%= f.submit %>
  </div>
<% end %>

<div class="hide" id="new_skills_form">
  <%= render partial: "skills_form", locals: {skill: false} %>
</div>

パーシャルはとてもシンプルです。ここで行っているのは、値を配列に格納することだけです...

<div class="skillsForm">
  <%= label_tag 'tag' %>
  <%= text_field_tag 'tags[]' %>
  <%= label_tag 'weight' %>
  <%= text_field_tag 'weights[]' %>
</div>

...これがjavascriptです...本当に簡単です。#addNewTagがクリックされたら、#new_skills_formを#skillSetに追加します

$(document).ready(function(){
  $("#addNewTag").click(function(){
    $("#skillSet").append($("#new_skills_form").html());
  });
});

...そして最後に、コントローラのアクションが配列を分解して保存します...

def create
    @skill = Skill.new(params[:skill])
    tags = params[:tags]
    weights = params[:weights]

    tags.each_with_index do |tag, index|
      tag = Tag.create :name => tag
      Skill.create :tag_id => tag.id, :weight => weights[index]
    end
  end
于 2013-07-29T14:27:21.583 に答える