[英]How to render a partial only when a user clicks the corresponding link?
所以目前我有一个使用bootstrap的按钮下拉列表,并且取决于从下拉列表中选择哪个项目,javascript用于显示或隐藏局部。 这些部分实际上显示在引导模式窗口中。
问题在于,javascript会根据所选的按钮下拉列表一次向用户“显示”一个部分,但所有部分都会在模态中呈现,它们只是从视图中隐藏。
我认为最好不要在模式中渲染所有部分并隐藏它们,而是仅在用户从下拉菜单中选择它们时才调用它们,这将是更好的性能明智的选择。
我不确定如何从按钮下拉列表中完成部分调用。 也许我只需要使用link_to调用的部分路由,并剪切掉所有JavaScript? 类似于<li><%= link_to "test", my_partial_path(@user) %></li>
这是我的按钮下拉列表和javascript
<div class="col-xs-6 text-right">
<!-- Button dropdown -->
<div class="btn-group">
<button type="button" class="btn btn-success dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Add <span class="caret"></span>
</button>
<ul id="select_id" class="dropdown-menu pull-right">
<li id="cert0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Certification</a></li>
<li id="course0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Course</a></li>
<li id="award0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Award or Honor</a></li>
<li id="language0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Language</a></li>
<li id="patent0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Patent</a></li>
<li id="publication0" class="dropdown-item"><a href="#achievementModal0" data-toggle="modal">Publication</a></li>
</ul>
</div>
</div><!-- ./col-xs-6 -->
<!-- renders different partials within the modal based off user selection -->
<script>
$('li.dropdown-item').click(function ()
{
//alert(this.id);
if (this.id == "cert0")
$("div#cert").show();
else
$("div#cert").hide();
if (this.id == "course0")
$("div#course").show();
else
$("div#course").hide();
if (this.id == "award0")
$("div#award").show();
else
$("div#award").hide();
if (this.id == "language0")
$("div#language").show();
else
$("div#language").hide();
if (this.id == "patent0")
$("div#patent").show();
else
$("div#patent").hide();
if (this.id == "publication0")
$("div#publication").show();
else
$("div#publication").hide();
});
</script>
这是模态主体,其中所有部分均被渲染,但一次仅显示一个,其余部分被隐藏。
<div class="modal-body">
<!-- a partial is shown based on the user dropdown selection, other partials hidden -->
<div id="award">
<%= render partial: "awards/new_award_modal" %>
</div>
<div id="cert">
<%= render partial: "certifications/new_certification_modal" %>
</div>
<div id="course">
<%= render partial: "courses/new_course_modal" %>
</div>
<div id="language">
<%= render partial: "languages/new_language_modal" %>
</div>
<div id="patent">
<%= render partial: "patents/new_patent_modal" %>
</div>
<div id="publication">
<%= render partial: "publications/new_publication_modal" %>
</div>
</div><!-- modal body -->
我能想到的任务有两种选择:
您已经在实现第一个。 但是,哪种方法性能更好取决于使用情况。 如果您希望用户单击会话中的几个链接,请使用ajax方法。
如果您希望用户单击几乎所有部分或多次重新访问某些部分,那么您当前的方法会更好。 这是因为,使用ajax方法时,每次用户单击链接时,您都必须向服务器请求部分请求。 但是,您可以通过在本地缓存主体来优化方法(如果您不希望它随每个请求而改变)。
Ajax方法使用远程链接。 当用户单击链接时,会发出ajax请求。 服务器返回一段JavaScript代码作为响应,该代码在浏览器上运行以呈现部分内容。 这是一个例子。 假设您的模态对话框有一个部分可以创建一个新的奖励,并且要呈现的模态为awards/new_award_modal
<%= link_to "New Award", controller: "awards", action: :new, :remote => true %>
在奖项负责人中
def new
@new_award = Award.new
respond_to do |format|
format.js
end
end
首先给模式容器指定一个id:
<div class="modal-body" id="my-modal">
</div>
创建一个views / awards / new.js.erb。 在这里,您将编写javascript代码以呈现部分
#views/awards/new.js.erb
$("#my-modal").html("<%= escape_javascript(render partial: 'awards/new_award_modal', locals: { award: @new_award } ) %>");
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.