我可以使用 ActionCable 来刷新页面吗?

Can I use ActionCable to refresh the page?

我最近一直在尝试为壁球比赛创建一个实时计分系统。我已经设法使用带有 Rails 5 的 ActionCable 来自动更新页面上的分数,但我想知道是否可以告诉 Rails 在特定条件下刷新页面遇见了

例如,如果游戏已经结束,则会显示一个不同的页面,说明玩家在游戏之间休息。我需要页面完全刷新才能发生这种情况。

在我的数据库中,布尔值 'break' 在游戏结束时被标记为真,然后视图使用条件 if/else 语句来决定显示什么。

我用来更新分数的代码附在下面,我在想一些类似if data.break == true的东西,然后页面会自动刷新。

// match_channel.js (app/assets/javascripts/channels/match_channel.js)

$(function() {
  $('[data-channel-subscribe="match"]').each(function(index, element) {
    var $element = $(element),
        match_id = $element.data('match-id')
        messageTemplate = $('[data-role="message-template"]');


    App.cable.subscriptions.create(
      {
        channel: "MatchChannel",
        match: match_id
      },
      {
        received: function(data) {
          var content = messageTemplate.children().clone(true, true);
          content.find('[data-role="player_score"]').text(data.player_score);
          content.find('[data-role="opponent_score"]').text(data.opponent_score);
          content.find('[data-role="server_name"]').text(data.server_name);
          content.find('[data-role="side"]').text(data.side);

          $element.append(content);
        }
      }
    );
  });
});

我不知道这种事情是否可行,而且我不擅长任何 Javascript 相关的事情,所以我很感激任何帮助。

谢谢。

重新加载当前页面相对简单。如果您使用的是 Turbolinks,则可以使用 Turbolinks.visit(location.toString()) 触发对当前页面的重新访问。如果您不使用 Turbolinks,请使用 location.reload()。因此,您的 received 函数可能如下所示:

received: function(data) {
  if (data.break) {
    return location.reload();
    // or...
    // return Turbolinks.visit(location.toString());
  }

  // your DOM updates
}

任何一种方式都相当于用户点击重新加载按钮,因此它会触发另一个 GET,调用您的控制器和 re-renders 视图。