ruby-on-rails - Action 电缆不工作我必须刷新两个选项卡才能看到消息

标签 ruby-on-rails ruby ruby-on-rails-5

这是 room.coffee 的代码:

App.room = App.cable.subscriptions.create "RoomChannel",
  connected: -> 
  disconnected: -> 

  received: (data) ->
    $('#messages').append "<p>#{data}</p>"    

  speak: (message) ->
    @perform 'speak' , message: message

有线电视.咖啡:

@App ||= {}
App.cable = ActionCable.createConsumer()

房间.咖啡:

$ ->
    $messages = $('messages')
    $messages.scrollTop $messages.prop('scrollHieght')
    $('#message_input').focus()

$(document).on 'keypress','message_input','e'->
    if e.keycode == 13 and e.target.value
    App.room.speak(e.target.value)
    e.target.value = ''
    e.preventDefault()

房间 channel :

class RoomChannel < ApplicationCable::Channel
  def subscribed
     stream_from "room_channel"
  end

  def unsubscribed
    # Any cleanup needed when channel is unsubscribed
  end

  def speak(data)
    message.create content: data['message']
  end
end

广播消息:

 def perform(message)
    Actioncable.server.broadcast 'room_channel',render_message(message)
  end
  private
  def render_message(message)
    ApplicationController.renderer.render_message
  end

当创建新消息时,它不会自动加载我浏览器的所有消息,直到页面不再重新加载。

最佳答案

我遇到了类似的问题。尝试在房间 View 中包含 cable.coffee/js。

<%= javascript_include_tag 'cable', 'data-turbolinks-track': 'reload' %>

您还需要将 cable.js 添加到/config/initializers/assets.rb。

Rails.application.config.assets.precompile += %w( cable.js )

关于ruby-on-rails - Action 电缆不工作我必须刷新两个选项卡才能看到消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38460353/

相关文章:

ruby-on-rails - ActiveRecord::RecordNotFound "Couldn' t 找到 id=new 的用户”

javascript - rails : Accessing instance variable from not inline JS

ruby-on-rails - 为什么验证会覆盖旧限制

ruby-on-rails - 与 has_many 达到二级关联

ruby-on-rails - Heroku rake 迁移

ruby-on-rails-5 - 通过 Rails 5 API 和 Active Storage 接受图像

ruby - 在 rails 中上传文件时出现 ArgumentError(字符串包含空字节)

ruby-on-rails - 邮件预览中的固定装置

ruby-on-rails - Heroku语法错误;日志包含加扰的行号

ruby-on-rails - 在与 rails 的深层嵌套关联中查找记录