亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

狀態正在從用戶獲取輸入,但未顯示在 React.js 的網頁上

狀態正在從用戶獲取輸入,但未顯示在 React.js 的網頁上

守候你守候我 2023-08-10 15:37:24
實際上,我正在 React.js 中構建 Facebook Mesenger Clone,并使用了 Material UI。當我們運行代碼時,它會要求輸入用戶名。提供后我們可以在應用程序中發送消息。但是,一旦我們發送消息,我們只會在屏幕上打印用戶名該消息未顯示在網頁上。這是 App.js 代碼:    import React, {useEffect, useState} from 'react';import {Button, FormControl, Input, InputLabel} from "@material-ui/core";import Message from "./Message";import './App.css';function App() {    const [input, setInput] = useState('');    const [messages, setMessages] = useState([]);    const [username, setUsername] = useState('');    useEffect(() => {        setUsername(prompt('Please enter your name'));    }, [])    const sendMessage = (event) => {        event.preventDefault();        setMessages([...messages, {username: username, text: input}]);        setInput('');    }    return <div className="App">        <h1>Hey Mate! ??</h1>        <h2>Welcome {username}</h2>        <form>            <FormControl>                <InputLabel>Enter a message...</InputLabel>                <Input value={input} onChange={event => setInput(event.target.value)}/>                <Button disabled={!input} variant="contained" color="primary" type='submit' onClick={sendMessage}>Send                    Message</Button>            </FormControl>        </form>        {            messages.map(message => <Message username={username} message={message}/>)        }    </div>}export default App;
查看完整描述

1 回答

?
猛跑小豬

TA貢獻1858條經驗 獲得超8個贊

您在Message組件中獲取的道具是錯誤的。只需將其更改為


function Message({ message, username }) {

  ...

}


查看完整回答
反對 回復 2023-08-10
  • 1 回答
  • 0 關注
  • 123 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號