- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我对 React 很陌生。我正在使用具有通用渲染功能的 Nodejs/Express 构建一个简单的 React Web 应用程序。我还使用 socket.io 来实时更新一些信息。
在 socket.io 文档中,它指出您可以通过执行以下操作建立与服务器的连接:
const socket = io()
在客户端。但是,这对我不起作用。我从 socket.io-client 收到此错误:
if (null == uri) uri = loc.protocol + '//' + loc.host;
^
TypeError: Cannot read property 'protocol' of undefined
相反,我必须将 uri 传递给 io(),如下所示:
const socket = io('http://localhost:5050')
然后一切都按预期工作...我的问题是如何通过简单地执行第一种情况来建立 socket.io const socket = io()
(没有服务器的 IP 地址/端口)
这是我的 server.js:
require('babel-register')
const express = require('express')
const React = require('react')
const ReactDOMServer = require('react-dom/server')
const ReactRouter = require('react-router')
const ServerRouter = ReactRouter.ServerRouter
const socketIO = require('socket.io')
const http = require('http')
const _ = require('lodash')
const fs = require('fs')
var bodyParser = require('body-parser')
const PORT = 5050
const baseTemplate = fs.readFileSync('./index.html')
const template = _.template(baseTemplate)
const App = require('./js/App').default
const app = express()
var server = http.createServer(app)
var io = socketIO(server)
// middleware
app.use(bodyParser.json())
app.set('socketio', io)
app.use('/public', express.static('./public'))
app.use((req, res) => {
const context = ReactRouter.createServerRenderContext()
const body = ReactDOMServer.renderToString(
React.createElement(ServerRouter, {location: req.url, context: context},
React.createElement(App)
)
)
res.write(template({body: body}))
res.end()
})
console.log('listening on port', PORT)
server.listen(PORT)
还有我的带有套接字的组件:
import React, { Component } from 'react'
const {string, bool, object} = React.PropTypes
const io = require('socket.io-client')
const socket = io('http://localhost:5050') // I want to change this!
class WelcomeMsg extends Component {
constructor (props) {
super(props)
this.state = {
text: ''
}
}
componentDidMount () {
socket.on(this.props.location.pathname, (mesg) => {
this.setState({text: mesg})
})
}
componentWillUnmount () {
socket.off(this.props.page)
}
render () {
<div>
{this.state.text}
</div>
}
export default WelcomeMsg
最佳答案
事实证明,这确实有效,毕竟,如果我这样设置的话:
import React, { Component } from 'react'
const {string, bool, object} = React.PropTypes
const io = require('socket.io-client')
let socket
class WelcomeMsg extends Component {
constructor (props) {
super(props)
this.state = {
text: ''
}
}
componentDidMount () {
socket = io()
socket.on(this.props.location.pathname, (mesg) => {
this.setState({text: mesg})
})
}
componentWillUnmount () {
socket.off(this.props.page)
}
render () {
<div>
{this.state.text}
</div>
}
export default WelcomeMsg
基本上,如果我在组件安装后初始化套接字。我猜想需要先安装该组件,然后才能获取要连接的默认地址。
关于node.js - 如果不将服务器 uri 传递给客户端的 io(),则无法使用 SocketIO,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43740883/
使用 ruby 1.9.2-p290。我在尝试解析如下 URI 时遇到问题: require 'uri' my_uri = "http://www.anyserver.com/getdata?anyp
根据 http://tools.ietf.org/html/rfc3986和 http://en.wikipedia.org/wiki/Uniform_resource_identifier , UR
如何在文本 block 中发现 URI? 这个想法是将这样的文本运行变成链接。如果只考虑 http(s) 和 ftp(s) 方案,这很容易做到;但是,我猜测一般问题(考虑 tel、mailto 和其他
我的一些网址上有一些特殊字符。例如: http://blabla.com/title/?t=burası 当我从其他页面提供指向该页面的链接时,我使用: URI.encode(s) 产生这个链接: /
我在 Windows Mobile 上使用紧凑型框架/C#。 在我的应用程序中,我通过序列化对象并使用 HttpWebRequest/POST 请求向上发送信息来将数据上传到服务器。在服务器上,发布数
我正在做一个实验,我发现将 Canvas 转换为 blob,然后转换为数据 URI 会导致与直接从 Canvas 获取数据 URI 不同的 URI。打开时的内容在两个 URI 上几乎相同。 使用 bl
我正在尝试在 Rails 3 中实现 OAuth 提供程序。当我尝试授权客户端应用程序时,出现此错误。我正在使用 RESTful auth 插件和 pelles OAuth 插件。当我通过 Rails
我有一个编码的 UI 测试方法: public void MyTestMethod() { string baseUrl = "www.google.com"; GlobalVaria
我知道这是一个常见的错误,我正在使用一个已知的解决方案,但它仍然给我同样的错误: require 'open-uri' url = "http://website.com/dirs/filex[a]"
我正在尝试使用 .NET 中的 HttpClient 来使用 Web 服务,并且在我完成了 msdn 中提到的所有步骤之后 o 出现以下异常:提供了无效的请求 URI。请求 URI 必须是绝对 URI
我正在尝试检索文件的 URI。该文件存储在: /storage/emulated/0/AppName/FileName.png 如果我使用 Uri.fromFile(file),我得到的是 file:
我想知道 (SIP) URI 中的不同参数分隔符表示什么? 部分以;分隔,例如: . 其他用?隔开和 & ,例如: 最佳答案 SIP 分隔符规则来自RFC 2396 RFC 3986 已弃用.但是在
我想调用decodeUrl(...),我这样做是: import "dart:uri"; main() { decodeUrl("str"); } 但是现在有了最新的Dart-SDK,它会报告
在 URI 中,空格可以编码为 + .既然如此,那么在创建具有国际前缀的 tel URI 时是否应该对前导加号进行编码? 哪个更好?两者在实践中都有效吗? Call me Call me 最佳答案 不
我试图弄清楚电子邮件地址的格式是否可以说符合 URI 的定义,但到目前为止我还没有找到明确的确认。我希望有人可以在这里为我提供一些见解。预先感谢:) 最佳答案 是的,但带有“mailto:”前缀。 U
因此,我尝试将 ID 参数附加到 URI 的末尾,当用户单击我的列表中的项目时,用户将被发送到该 URI。我的代码如下: public void onItemClick(AdapterView par
这是 Converting file path to URI 的后续问题. 考虑: require 'uri' uri = URI.join('file:///', '/home/user/dir1/
我在 pl/sql 中创建了一个名为 tester 的包。但我收到以下消息。 绝对URI中的相对路径:java.net.URI.checkPath(URI.java:1823) --Package D
我在 gitlab 上有一个 git repo,使用私有(private) pod 和其他公共(public) pod,下面是我的 Podfile source 'git@gitlab.mycompa
我正在尝试将我的 Rails 应用程序推送到 heroku 上,我正在使用 heroku RedisToGo 附加组件我经历过这个tutorial并完成了那里提到的所有步骤。 但是在推送 heroku
我是一名优秀的程序员,十分优秀!