Rails 5:使用AJAX更新操作

时间:2017-03-06 18:37:05

标签: 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 有相同的工作,但在用户表中:

$('#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')) }} 。基本上它不会第一次刷新,并且在第二轮中刷新必须在第一轮渲染的值。一些奇怪的行为。 有没有人知道我的部分内容会发生什么?

1 个答案:

答案 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请求通常不会使前端崩溃,因此您不会在屏幕上看到错误。

希望这些帮助