窗.WebSocket - 未定义窗口

window.WebSocket - window is not defined

本文关键字:窗口 未定义 WebSocket      更新时间:2023-09-26

我在这里有点超出我的舒适区,所以寻求一些指导。我正在尝试访问一个 api 以显示实时指标,使用语音长生不老药 (https://www.npmjs.com/package/phoenix-elixir) - 我只是想先让它运行,所以已经加载了他们的示例代码并连接到 api(原谅我,如果术语全错了,我是新手!

这是我的代码:

import {Socket} from 'phoenix-elixir';
let socket = new Socket('ws://API_URL_HERE', {params: {'auth-token': 'AUTH_TOKEN'}})
socket.connect()
let channel = socket.channel('updates:new', {})
channel.join()
  .receive('ok', resp => { console.log('Joined successfully', resp) })
  .receive('error', resp => { console.log('Unable to join', resp) })
channel.on('update', payload => {
  console.log('Received: ' + payload);
  console.log(payload);
})
export default socket

当我运行babel index.js | node时,出现错误:this.transport = opts.transport || window.WebSocket || LongPoll;ReferenceError: window is not defined

只是一些建议来指出我正确的方向会很棒。窗口没有定义,因为它需要一个 dom?我需要服务器来运行它吗?

谢谢:)

我只是移植了客户端以与node.JS兼容。

这是链接 https://github.com/mcampa/phoenix-channels

与原始客户端的区别在于,这不使用长轮询,您需要传递绝对 url 而不是相对 url。

要安装它,请运行:

npm install --save phoenix-channels

与原始 API 相同:

const { Socket } = require('phoenix-channels')
let socket = new Socket("ws://example.com/socket")
socket.connect()
// Now that you are connected, you can join channels with a topic:
let channel = socket.channel("room:lobby", {})
channel.join()
  .receive("ok", resp => { console.log("Joined successfully", resp) })
  .receive("error", resp => { console.log("Unable to join", resp) })

phoenix-elixir是客户端库,应该在浏览器而不是节点环境中使用。您应该使用代码创建 html 页面并在浏览器中打开它以进行测试。