js.erb文件在控制器中的respond_to之后无法加载

时间:2014-09-04 09:32:46

标签: javascript jquery ruby-on-rails ajax

我在视图中需要两个按钮,但只有一个应该使用遥控器,所以我决定使用链接和提交按钮,方法如下:

查看

  <%= form_for(@new_word , :url => {:action => "create"}) do |f| %>

  ... skipped code  ...

  <%= link_to("build word", '#', :class => "build", "data-button" => "build") %>

   ... skipped code ...
  <div id="build_name"></div>

  <%= submit_tag l(:btn_save), :name => 'btn_save' %>

  <% end %>


 <script type="text/javascript">
  jQuery(".build").click(function(){
        var form_value = jQuery('#new_nc_project').serialize();  
        var button = $(this).data("button");    
        var content = $('#nc_project_keyword_tokens').val(); 
        if(button == "build"){
          $.ajax({
            type:'POST', 
            url: '<%= url_for :action => 'build' %>', 
            data: $.param({keyword_tokens: content})
          });
        }
     });
 </script>

控制器

def build
@response = {resp: "text"} //just example text for testing
respond_to do |format|
  format.json { render json: @response }
  format.js   { render js: @response }
end

build.js.erb

$('#build_name').append('<p><%= @response[:resp] %></p>');

如果我查看我的服务器控制台,我看不到&#34; build.js.erb&#34;文件。

我做错了什么,还有另一种方法可以让#34; @回应&#34;在视野中可见?

谢谢,点

1 个答案:

答案 0 :(得分:1)

要渲染build.js.erb,您应该这样做

respond_to do |format|
  format.json { render json: @response }
  format.js # this will render build.js.erb by default.
end