- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚开始 ReactJS,但在理解状态和 props 方面仍然存在问题。
我正在尝试使用 node.js、React 和 Socket.io 构建一个聊天应用程序。服务器端一切正常,但是,我在显示数据时遇到了一些困难。
这是我的问题:我有一个包含三个组件的应用程序,组织如下:
我希望 Chat 组件保存由服务器和 messageInput 组件提供的消息列表。
由于聊天组件将保存状态,因此我有一个初始化两个变量的构造函数。但是,当我从 messageInput 更新这些变量时,组件将重新渲染,导致构造函数再次被调用,状态重新初始化。
class Chat extends React.Component{
constructor(){
super()
this.state = {
messageList: [],
username:null
}
}
我注意到从服务器检索的数据不会导致状态设置为默认值。输入重置聊天组件中的状态值,但似乎正在按预期工作:消息发送到服务器,并显示给其他客户端。
我想我还不太明白如何正确设置组件中的状态。您将在下面找到一些客户端代码。
提前致谢!
const io = require('socket.io-client')
const socket = io.connect('localhost:4242')
class Chat extends React.Component{
constructor(props){
super(props)
this.state = {
messageList: [],
username:null
}
}
componentDidMount(){
if (this.state.username == null){
var user = prompt("Enter username:")
this.setState(
{username: user}, function(){
socket.emit('new_client', this.state.username)
this.addMessage({
text: this.state.username + " has entered the chat",
sender:"server",
timestamp: Date.now()})
})
}
socket.on('broadcast', data =>{
let newList = this.state.messageList.concat([data])
this.setState({messageList: newList})
})
}
addMessage(object) {
const array = this.state.messageList
let newList = array.concat([object])
this.setState({
messageList: newList})
}
sendMessage(messageString){
const message = {sender: this.state.username,
text: messageString,
timestamp: Date.now()}
socket.emit('message', message)
this.addMessage(message)
}
render(){
return(
<div className="app">
<MessageList
messageList={this.state.messageList}
username={this.state.username}
/>
<MessageInput
sendMessage={i=> this.sendMessage(i)}
/>
</div>
)
}
}
class MessageList extends React.Component{
//USED TO DISPLAY CHAT MESSAGES, WORKS WELL
}
class MessageInput extends React.Component{
constructor(props){
super(props)
this.state = {
message:''
}
this.handleChange = this.handleChange.bind(this)
this.handleSubmit = this.handleSubmit.bind(this)
}
handleChange(event){
this.setState({
message: event.target.value
})
}
handleSubmit(event){
this.props.sendMessage(this.state.message)
this.setState({
message:''
})
}
render(){
return(
<form
onSubmit={this.handleSubmit}
className="send_message_form">
<input
onChange={this.handleChange}
value={this.state.message}
placeholder="Input a new message"
type="text"/>
</form>
)
}
}
最佳答案
重新渲染组件不会导致其状态重置。尝试将您的 handleSubmit
函数更改为:
handleSubmit(event){
this.props.sendMessage(this.state.message)
this.setState({
message:''
})
event.preventDefault(); // So the page won't refresh
}
关于javascript - ReactJS:状态在每次更新时设置回初始值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58453805/
我有一个 MvvmCross MvxSpinner在 Android 中绑定(bind)。用户选择一个值并反射(reflect)在我的属性 MealTypeSelected . 微调器允许用户选择膳
我有一个带有某种类型函数指针的公共(public)变量的表单,如下所示: {...} interface type TExternalFunction = function(var x : TAn
this question中的答案对我理解如何在 IBAction 方法中检索步进器值很有帮助(我投了赞成票),但我仍然不理解在我第一次加载 View 时如何获取步进器的初始值。 我想将初始值设置为
Apple 文档指出: The willSet and didSet observers of superclass properties are called when a property is
我正在将 ColdFusion 应用程序转换为 C#(我是 CF n00b)。 我有一个脚本执行 cfquery,然后执行 cfloop 的结果,它似乎试图将当前行与其下一行进行比较。它似乎试图确保它
我在为 antd 动态表单设置初始值时遇到问题。有什么方法可以在动态中初始化值吗?它需要使用 getFieldDecorator 注册字段。但对于动态字段,该字段之前没有注册。 我收到这个错误:不能在
是否可以动态地为 forms.FileField() 赋予初始值? 最佳答案 我不确定,如果这就是你想要的,但是…… 显然,您不能为文件输入设置初始数据(这意味着您将文件发送给用户)。 Django
我对 Django 表单中 DateTimeField 的初始值没有什么问题。 我在 forms.py 中有声明 class FaultForm(forms.ModelForm): ...
如何使用代码设置 slider 初始值?我知道如何在属性检查器中执行此操作。我想在我的应用程序启动时使用“UserDefault”作为初始值,当我的应用程序第一次启动时,我想将初始值设置为“1.0”
我有一个 RadioButton其 IsChecked 的元素属性绑定(bind)到 MyProperty在 ViewModel . Binding有模式OneWayToSource由于某些原因,它会
我有一个ViewModel类,看起来像这样: class EditUserViewModel( private val initUser: User, ) : ViewModel() {
有人可以帮我解决我的问题吗,问题是我希望我输入到文本字段的第一个初始值只是从 1 到 9 的数字,我正在使用小数垫,所以我也不希望我的初始值是小数点,但在第一个值(仅从 1 t0 9 开始的数字)之后
我正在使用 NSFetchedResultsController 从 CoreData 获取数据并加载包含四个部分的 TableView 。当应用程序第一次运行时,它可以完美地工作,将 plist 加
使用 primeNg 下拉组件,我试图用初始值初始化下拉列表,但没有成功,我使用的是响应式(Reactive)方法。 我检查了 primeNg 文档和演示 - 几乎所有示例都使用模板驱动,我希望模型驱
如何在 ASP.NET 中设置数据绑定(bind)下拉列表的初始值? 例如,我想要这些值,但要显示的第一个值应该是 -- Select One ---,且值为空。 最佳答案 我想你想做的是这样的:
我知道我不能给 BehaviorSubject一个 Observable 值,但我需要一种方法来解决这个问题。在应用程序初始化时,我正在获取当前用户(如果存在),我需要提供 BehaviorSubje
这是我在这里的第一篇文章,所以我希望它是全面的。 我正在使用 AngularJs,并且我使用 Angular 指令添加了一个 JqueryUI slider 。我找到了很多关于如何做到这一点的例子,但
如何有效地为大型数组分配一个公共(public)初始值?例如,如果我有一个 100 x 100 x 100 的整数数组,其中所有初始值都应为零。 在 matlab 中我会简单地写: array = z
我正在为 iOS 应用程序创建一个 Pebble 配套应用程序。我已经使用一些初始值设置了我的 AppSync: Tuplet initial_values[] = { TupletC
有件事我迟到了: const [object, setObject] = useState(new SomeObject()); 在这里,我们在每次重新渲染上构造一个SomeObject实例。然后,如
我是一名优秀的程序员,十分优秀!