我遵循轨道广播嵌套形式
例如:我在注册页面上有4个字段,在编辑页面上有12个字段(实际上,我需要更多的基本信息)
当新客户注册时,他们会在编辑页面上填写所有12个字段,所有内容都很好。
但是,当老客户登录(在创建嵌套表单之前已经注册)时,他们现在并没有得到所有字段,只得到4个字段
我使用的是这样的东西:
控制器
def new
@user = User.new
@user.build_user_nickname_live
@user.build_user_twitter_chipcount
@user.user_twitter_reals.build
@user.user_twitter_fakes.build
end
def edit
@user = User.find(current_user.id)
end
模型
has_one :user_nickname_live
accepts_nested_attributes_for :user_nickname_live
has_one :user_twitter_chipcount
accepts_nested_attributes_for :user_twitter_chipcount
has_many :user_twitter_reals, :dependent => :destroy
accepts_nested_attributes_for :user_twitter_reals,
:allow_destroy => true
has_many :user_twitter_fakes, :dependent => :destroy
accepts_nested_attributes_for :user_twitter_fakes,
:allow_destroy => true
视图
<%= nested_form_for(resource, :as => resource_name,
:url => registration_path(resource_name), :html => { :method => :put }) do |f| %>
<div style="overflow: hidden;display: block;">
<%= f.fields_for :user_nickname_live do |user_nickname_live| %>
<!--span 2 and 4 with min-padding-->
<div class="span2 min-padding">
<label >Live Nickname</label>
</div>
<div class="span4 min-padding">
<div class="input-control text">
<%= user_nickname_live.text_field :nickname,:style=>"max-width: 253px;", :placeholder=>"Live nickname",:onchange=>"changeInfo();" %>
</div>
</div>
<!--ends-->
<% end %>
</div>
<div style="overflow: hidden;display: block">
<%= f.fields_for :user_twitter_chipcount do |user_twitter_chipcount| %>
<!--span 2 and 4 with min-padding-->
<div class="span2 min-padding">
<label >Chip count account</label>
</div>
<div class="span4 min-padding">
<div class="input-control text">
<%= user_twitter_chipcount.text_field :twitter_url,:style=>" max-width: 250px;", :id=>"twitter_url", :placeholder=>"Chip count account" ,:onchange=>"changeInfo();" %>
</div>
</div>
<!--ends-->
<% end %>
</div>
<div id="real-one" style="display:block;position: relative;">
<div class="add-click">
<%= f.link_to_add "", :user_twitter_reals, :class=>"icon-plus",:style=>"font-size: 14px;", :data => { :target => "#real-field" } %>
</div>
<%= f.fields_for :user_twitter_reals do |real_one| %>
<div id="real-field" style="overflow: hidden;">
<!--span 2 and 4 with min-padding-->
<div class="span2 min-padding">
<label >Real</label>
</div>
<div class="span4 min-padding">
<div class="input-control text" >
<%= real_one.text_field :twitter_url,:style=>"max-width: 250px;",:placeholder=>"Real",:onchange=>"changeInfo();" %>
<%= real_one.link_to_remove "", :class=>"icon-minus minus-click" %>
</div>
</div>
<!--ends-->
</div>
<% end %>
</div>
<div id="twitter-fake" style="display: block;position: relative;">
<div class="add-click">
<%= f.link_to_add "", :user_twitter_fakes, :class=>"icon-plus",:style=>"font-size: 14px;", :data => { :target => "#fake-field" } %>
</div>
<%= f.fields_for :user_twitter_fakes do |user_twitter_fake| %>
<div id="fake-field" style="overflow: hidden;">
<!--span 2 and 4 with min-padding-->
<div class="span2 min-padding">
<label >Fake</label>
</div>
<div class="span4 min-padding">
<div class="input-control text">
<%= user_twitter_fake.text_field :twitter_url,:style=>"max-width: 250px;",:placeholder=>"Fake",:onchange=>"changeInfo();" %>
<%= user_twitter_fake.link_to_remove "", :class=>"icon-minus minus-click" %>
</div>
</div>
<!--ends-->
</div>
<% end %>
</div>
<% end %>
请帮帮我。
当时,创建这些关联的旧用户并不存在。
因此,如果一个老用户现在想编辑其个人资料,比如:
<%= f.fields_for :user_nickname_live do |user_nickname_live| %>
不能显示任何内容,因为尚未在数据库中建立关联。
你可以创建一个迁移,或者rake任务,或者后台任务,或者在irb中修复它,为老用户用户添加关联
我没有试过,但应该有效。创建一个迁移调用,例如:build_user_nickname_live_associations并放入内部:
def up
users = User.find(:all)
users.each do |u|
unless u.nick_name_live.present?
u.build_nick_name_live
u.save
end
end
end