我有 /views/layouts/_navigation.html.erb ,其中生成了用户个人资料部分:
<nav class="navbar-default navbar-static-side" role="navigation">
<div class="sidebar-collapse">
<ul class="nav metismenu" id="side-menu">
<!-- Here we render user profile -->
<div id='userprofile'>
<%= render 'layouts/userprofile' %>
</div>
<!-- Here we render menu -->
<% cache "#{I18n.locale}_menu" do %>
<%= render 'layouts/menu' %>
<% end %>
</ul>
</div>
</nav>
<!-- Here we render modal window dialog -->
<%= render 'users/dialog' %>
在 /views/layouts/_userprofile.html.erb 中我有这个:
<div class="dropdown profile-element">
<span>
<img alt="image" class="img-circle" src="<%= image_url 'profile_small.jpg' %>"/>
</span>
<a data-toggle="dropdown" class="dropdown-toggle" href="#">
<span class="clear">
<span class="block m-t-xs">
<strong class="font-bold"><%= current_user.name %></strong><b class="caret"></b>
</span>
</span>
</a>
<ul class="dropdown-menu animated fadeInRight m-t-xs">
<li><a href=""><%= t('.sellerdash') %></a></li>
<li><a href=""><%= t('.buyerdash') %></a></li>
<li><%= link_to t('.profile'), current_user %></li>
<li><%= link_to t('.settings'), edit_user_path(current_user), remote: true %></li>
<li class="divider"></li>
<li><%= link_to t('.logout'), logout_path %></li>
</ul>
</div>
单击“设置”时,将打开模态窗口并可以编辑“用户设置”。 /views/users/update.js.erb 有相同的工作,但在用户表中:
$('#dialog').modal('toggle');
$('#user_<%= @user.id %>').replaceWith('<%= j render (@user) %>')
更新用户设置后,我想刷新_userprofile.html.erb
部分以显示新信息,例如用户名。
到目前为止,我认为我需要将此行添加到 /views/users/update.js.erb
$('#userprofile').html('<%= j render 'layouts/userprofile', locals: {user: @user} %>')
然而,它不起作用。
我该如何解决这个问题?谢谢!
更新
我的/controllers/users_controller.rb中的更新操作如下所示:
def update
respond_to do |format|
if @user.update(user_params)
format.json { head :no_content }
format.js
else
format.json { render json: @user.errors.full_messages,
status: :unprocessable_entity }
end
end
end
我发现userprofile.html.erb
只有在连续第二次试用后才会刷新{{ form_widget(form.someday.hour|date('h')) }}
。基本上它不会第一次刷新,并且在第二轮中刷新必须在第一轮渲染的值。一些奇怪的行为。 有没有人知道我的部分内容会发生什么?
答案 0 :(得分:1)
作为第一个衡量标准,我首先会检查请求是否作为JS触发。你可以在控制台中检查它
还要注意在整个javascript代码中使用单引号
$('#userprofile').html("<%= j render 'layouts/userprofile', locals: {user: @user} %>")
注意我添加的双引号
另外我假设你有你的控制器
respond_to do |format|
format.js
end
在这种情况下,不需要传递本地,因为它们可以直接访问部分
所以代码变成了
$('#userprofile').html("<%= j render 'layouts/userprofile' %>")
还要确保在控制台中看不到任何错误。 Javascript请求通常不会使前端崩溃,因此您不会在屏幕上看到错误。
希望这些帮助