操作电缆不工作我必须刷新两个选项卡才能看到消息

man*_*pta 5 ruby ruby-on-rails 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
Run Code Online (Sandbox Code Playgroud)

cable.coffee:

@App ||= {}
App.cable = ActionCable.createConsumer()
Run Code Online (Sandbox Code Playgroud)

rooms.coffee:

$ ->
    $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()
Run Code Online (Sandbox Code Playgroud)

roomchannel:

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
Run Code Online (Sandbox Code Playgroud)

Broadcostmessage:

 def perform(message)
    Actioncable.server.broadcast 'room_channel',render_message(message)
  end
  private
  def render_message(message)
    ApplicationController.renderer.render_message
  end
Run Code Online (Sandbox Code Playgroud)

在创建新消息时,它不会自动加载浏览器的所有消息,直到页面没有重新加载.

teg*_*ude 0

我有类似的问题。尝试在房间视图中包含cable.coffee/js。

<%= javascript_include_tag 'cable', 'data-turbolinks-track': 'reload' %>
Run Code Online (Sandbox Code Playgroud)

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

Rails.application.config.assets.precompile += %w( cable.js )
Run Code Online (Sandbox Code Playgroud)

  • 默认应用程序已经重新加载所有 JavaScript,cable 是其中的一部分。 (3认同)