我在视图中需要两个按钮,但只有一个应该使用遥控器,所以我决定使用链接和提交按钮,方法如下:
查看
<%= 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;在视野中可见?
谢谢,点
答案 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