嵌套的insert_html错误:Ruby On Rails&使用Javascript

时间:2009-04-23 22:07:11

标签: javascript ruby-on-rails

嘿大家好!这个问题让我绝对疯了!这似乎是Rails渲染JS的一个错误,但我不确定。

简要概要:

我正在尝试创建一个具有多个TRACK的RELEASE。这些TRACKS有很多TRACK_LINKS。然后,这些TRACK_LINK会关联TRACK_LINK_TYPE(mp3,m3u,播客等)。把它想象成一张专辑。因此,在添加发行版时,您可以添加专辑曲目,每个专辑曲目可以有不同的链接(mp3,m3u,播客等等)。我处于非常早期阶段并利用脚手架 - 用户可以在表单上创建一个版本,通过JS添加轨道并通过JS添加轨道链接。这一切都很好 - 但是当我在代码中使用“添加轨道链接”功能时,添加轨道不起作用!它默默地失败 - 没有错误,只是去#锚。

在主要发布表单中,我将TRACK局部渲染并添加链接以添加TRACK:

<div id="tracks">
    <%= render :partial => 'track', :collection => @release.tracks -%>
</div>

<%= add_track -%>

现在在TRACK部分,我正在渲染TRACK_LINK,并添加链接以添加TRACK_LINK:

<div class="track">
    <fieldset>
    <legend>Track</legend>
    <p> 
        <% @track = track %>
    <%= error_messages_for :track -%>

        <% fields_for_track(track) do |track_form| -%>
        Track Name
    <br />
    <%= track_form.text_field :name -%>
    <%= link_to_function "remove", "$(this).up('.track').remove()" -%>
    <% track_links_id = "track_links_#{Time.now.to_i.to_s}" %>
    <div id="<%= track_links_id %>">
            <%= render :partial => 'track_link', :collection => @track.track_links -%>              
    </div>
    <%= add_track_link track_links_id -%>   
    <% end -%>
    </p>
</fieldset>
</div>

在TRACK_LINK部分中,我正在创建TRACK_LINK字段(及其关联的TRACK_LINK_TYPE字段):

<div class="track_link">
    <% @track_link = track_link -%>
<% fields_for_track_link(track_link) do |track_link_form| -%>
    Track Link
    <br />
    <%= track_link_form.text_field :url -%>
    <%= select ("track_link_type", "id", @track_link_type.map {|type| [type.name, type.id]}) -%>        
        <%= link_to_function "remove", "$(this).up('.track_link').remove()" -%>     
<% end -%>
</div>

最后,这里是link_to_function辅助方法:

module ReleasesHelper
    def fields_for_track(track, &block)
        prefix = track.new_record? ? 'new' : 'existing'
        fields_for("release[#{prefix}_track_attributes][]", track, &block)
    end

    def fields_for_track_link(track_link, &block)
        prefix = track_link.new_record? ? 'new' : 'existing'
        fields_for("track[#{prefix}_track_link_attributes][]", track_link, &block)
    end

    def add_track
        track = Track.new
        track.track_links.build
        link_to_function 'Add Track' do |page| 
            page.insert_html :bottom, :tracks, :partial => 'track', :object => track
    end
end

    def add_track_link(name)
        link_to_function "Add Track Link" do |page|       
            page.insert_html :bottom, name, :partial => 'track_link', :object => TrackLink.new
    end
end
end

结果是每个link_to_function工作正常,但是当我同时具有“添加轨道”和“添加轨道链接”功能时,“添加轨道”link_to_function不起作用。关于它呈现“添加轨道链接”功能的一些东西搞乱了!为长屁股发帖道歉!希望它不烦人,有人可以帮忙吗?

最好的, 普利文

1 个答案:

答案 0 :(得分:1)

看看https://github.com/nathanvda/cocoon。文档很好,它可以节省您编写和维护此代码的费用。如果您有兴趣知道它是如何工作的,请查看源代码(它并不过分复杂)。祝你好运!