javascript - rails 5 : refresh partial in another partial with AJAX update action

标签 javascript jquery ruby-on-rails ajax

我有/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 执行相同的工作,但在 User 表中:

$('#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 仅在连续第二次尝试后才会刷新。基本上它不会第一次刷新,在第二轮中它会刷新必须在第一轮中渲染的值。一些奇怪的行为。 有人知道我的部分发生了什么吗?

最佳答案

作为第一个措施,我将首先检查请求是否作为 JS 触发。您可以在控制台中检查

还要注意在 JavaScript 代码中使用单引号

$('#userprofile').html("<%= j render 'layouts/userprofile', locals: {user: @user} %>")

注意我添加的双引号

我还假设你的 Controller 中有

respond_to do |format|
  format.js
end

在这种情况下,不需要传递局部变量,因为局部变量可以直接访问它们

所以代码变成了

$('#userprofile').html("<%= j render 'layouts/userprofile' %>")

还要确保在控制台中您没有看到任何错误。 JavaScript 请求通常不会使前端崩溃,因此您不会在屏幕上看到错误。

希望这些有帮助

关于javascript - rails 5 : refresh partial in another partial with AJAX update action,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42633096/

相关文章:

JavaScript - 为什么加法赋值运算符不能按预期工作?

jquery - 如何在 JQuery Datetimepicker 插件中仅显示日期?

ruby-on-rails - 更改 bundle 安装 Ruby 版本

javascript - 如何将 json 和特殊字符从 php 编码为 javascript?

javascript - 如何处理 json 数组以在 jquery 中打印 html dom 中的值?

ruby-on-rails - Mechanize 不通过 CSS 选择器方法识别 anchor 标记

ruby-on-rails - rspec 升级到 3.1.0 后,与 allowed_any_instance_of 一起使用的 and_call_original 不起作用

javascript - 如何获取输入值全部并进行加法

javascript - 我可以在 jointjs 元素中添加新属性吗?

javascript - IE9 注入(inject)脚本标签的执行顺序是否有已知的解决方法?