在反应中提交后清除文本字段

问题描述 投票:0回答:2

谁能帮忙如何在发送消息后清除文本字段?我尝试了很多方法但没有成功。我尝试使用 PreventDefualt 和 setFirstname('') 空字符串,但它也不起作用。感谢您的帮助,因为我需要解决这个问题

const [firstename, setFirstName] = useState('');
  const [lastename, setLastName] = useState('');
const sendCollectionRef = collection(db, 'messages');
  const [loader, setLoader] = useState(false);
  const creatSend = async () => {
    setLoader(true);

    await addDoc(sendCollectionRef, {
      Firstname: firstename,
      Lastname: lastename,
      Email: email,
      Message: message,
    })
      .then(() => {
        setLoader(false);
        setLastName('');

        alert('Your Message has been sent');
      })
      .catch((error) => {
        alert(error.message);
        setLoader(false);
      });
  };
<TextField
                      id="outlined-basic"
                      label="Message"
                      multiline
                      rows={4}
                      variant="outlined"
                      placeholder="Type Your Message"
                      fullWidth
                      style={{ backgroundColor: '#2b2b2b' }}
                      onChange={(event) => {
                        setMessage(event.target.value);
                      }}
                    />
                    <Grid xs={12} item class="send-spacer">
                      <LoadingButton
                        onClick={creatSend}
                        endIcon={<SendIcon />}
                        variant="contained"
                        style={{
                          background: loader ? '#ccc' : ' rgb(2, 2, 110)',
                        }}
reactjs firebase crud
2个回答
1
投票

通常,如果您不使用库来处理表单(例如 formik),则必须将每个文本字段值绑定到本地状态。

const [firstName, setFirstName] = useState('');
const [lastName, setLastName] = useState('');

<TextField name="firstName" value={firstName} onChange={e => setFirstName(e.target.value) ...... />
<TextField name="lastName" value={lastName} onChange={e => setLastName(e.target.value) ...... />

然后在提交处理程序中,将数据发送到服务器后,您可以重置字段值,只需更改状态:

setLastName('');
setFirstName('');

0
投票

const [firstName, setFirstName] = useState(''); const [lastName, setLastName] = useState('');

setFirstName(e.target.value) ...... /> setLastName(e.target.value) ...... /> 然后在提交处理程序中,将数据发送到服务器后,您可以重置字段值,只需更改状态即可:

setLastName({firstName: " "}); setFirstName({lastName: " "});

您还可以使用 useRef() 来清除值。

© www.soinside.com 2019 - 2024. All rights reserved.