肯定有一种方法可以做到这一点,而且需要一些工作,但是一旦掌握了它就很容易了。
首先,您需要将一个 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
您将不得不使用您为文件夹模型提供的任何属性。
这应该让你去你需要去的地方。如果您需要任何澄清,请告诉我。