尝试这样的事情.由于您正在处理套接字,因此您无需经历redux流,只需使用componentDidMount()生命周期状态即可获得实时更新.
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import io from 'socket.io-client';
// should listen to your sever with socket connection in this case its localhost:3000
let socket = io('http://localhost:3000');
class App extends Component {
constructor(props){
super(props);
this.state={
chat:[{message:'Hello everyone'}]
};
}
componentDidMount() {
socket.on('recive', data => {
console.log(data);
this.setState({chat:[...this.state.chat,data]});
})
}
msgthreads =()=> {
return this.state.chat.map((msg,index)=>{
return <div key={index} className="row message-bubble">
<span>{msg.message}</span>
</div>
});
}
sendmessage =()=> {
console.log(this.textInput.value);
socket.emit('send',{message:this.textInput.value});
}
App.propTypes = {
chat: PropTypes.array
}
render() {
return (
<div className="container">
<div className="row">
<div className="panel panel-default">
<div className="panel-heading">Panel heading without title</div>
<div className="panel-body">
<div className="container">
{this.msgthreads()}
</div>
<div className="panel-footer">
<div className="input-group">
<input type="text" className="form-control" ref={(input) => { this.textInput = input; }}/>
<span className="input-group-btn">
<button className="btn btn-default" type="button" onClick={this.sendmessage}>Send</button>
</span>
</div>
</div>
</div>
</div>
</div>
</div>
);
}
}
export default App;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1547 次 |
| 最近记录: |