肯定有一种方法可以做到这一点,而且需要一些工作,但是一旦掌握了它就很容易了。
首先,您需要将一个 jQuery 函数附加到change您的选择框的事件中。这可以通过在application.js文件中添加一些 javascript 来完成。我们想在这里这样做,所以我们的 javscript 保持不引人注目。你可以在你的application.js文件中尝试这样的事情:
$(document).ready(function(){
$("#select_field_id").change(function(){
var id = $(this).children(":selected").val();
var params = 'some_id=' + id;
$.ajax({
url: "/some_controller/change_folder",
data: params
})
});
这样做是将匿名函数附加到change具有 id 的选择字段的事件select_field_id。当该字段更改时,id所选选项的 var 存储在 varid中,然后我们为将要发送的请求创建一个参数 do var params = 'some_id=' + id;。some_id将是您正在更改的任何内容的 id (folder_id如果这是您在示例中使用的内容)。
现在我们需要在控制器中创建将处理此请求的方法。因此,使用文件夹示例,将其添加到文件夹控制器:
def change_folder
@folder = Folder.find(params[:some_id])
respond_to do |format|
format.js
end
end
这只是根据您的 ajax 请求发送到的 id 找到一个文件夹change_folder。它还将寻找相应的change_folder.js.erb或change_folder.js文件来渲染。
现在我们需要编写一个change_folder.js.erb文件。我们需要用我们获得的新文件夹替换页面某些部分的 HTML,因此您应该有某种div或其他具有唯一 ID 的部分。
在里面change_folder.js.erb,我们可以这样写:
$('#your_div').html("<%= escape_javascript(render(partial: "folder",
locals: { :folder => @folder })).html_safe %>")
_folder.html.erb这将呈现与文件位于同一目录中的部分调用change_folder.js.erb。部分将需要使用 @folder 变量来显示字段,因此您需要以下内容:
<%= @folder.name %>
<%= @folder.last_updated %>
在你的_folder.html.erb偏里面。当然只是由文件夹模型的属性组成.name。.last_updated您将不得不使用您为文件夹模型提供的任何属性。
这应该让你去你需要去的地方。如果您需要任何澄清,请告诉我。