gpt4 book ai didi

reactjs - 输入字段未删除 React

转载 作者:行者123 更新时间:2023-12-04 17:10:04 24 4
gpt4 key购买 nike

我正在学习 React,我创建了一个简单的待办事项列表应用程序,并且我正在尝试删除输入字段,就像我对按键功能上的 onClick 功能所做的那样。但是,当我在该按键功能上使用 setTodoInput(""); 时,它不会呈现相同的效果。它只显示输入的第一个字符。如果我从按键功能中注释掉 setTodoInput("");,它工作正常,但输入字段不会删除。我不明白为什么虽然我有一个受控输入,但它的功能却不一样。如果有人能解释一下,我们将不胜感激。

这是我的应用程序文件的代码:

import React, { useState } from "react";
import InputArea from "./InputArea";
import ToDoTask from "./ToDoTask";

function App() {
const [todoTasks, setTodoTasks] = useState([]);

function addTask(todoInput) {
setTodoTasks((prevTodoTasks) => {
return [...prevTodoTasks, todoInput];
});
}

function handleKeyPress(event) {
if (event.key === "Enter") {
setTodoTasks((prevTodoInput) => {
const newTodoInput = event.target.value;
return [...prevTodoInput, newTodoInput];
});
// const newTodoInput = event.target.value;
// setTodoTasks((prevTodoTasks) => {
// console.log(newTodoInput);
// return [...prevTodoTasks, newTodoInput];
// });
// }
}
}

function deleteTodoTask(id) {
setTodoTasks((prevTodoTasks) => {
return prevTodoTasks.filter((task, i) => {
return i !== id;
});
});
}

return (
<div className="container">
<div className="heading">
<h1>To-Do List</h1>
</div>
<div className="form">
<InputArea onAdd={addTask} onKeyPress={handleKeyPress} />
</div>
<div>
<ul>
{todoTasks.map((todoTasks, i) => (
<ToDoTask
key={i}
id={i}
text={todoTasks}
onChecked={deleteTodoTask}
/>
))}
</ul>
</div>
</div>
);
}

export default App;

我还创建了一个输入组件:

import React, { useState } from "react";

function InputArea(props) {
const [todoInput, setTodoInput] = useState("");

function handleChange(event) {
const newInput = event.target.value;
setTodoInput(newInput);
}

return (
<div className="form">
<input
onKeyDown={(event) => {
props.onKeyPress(event);
setTodoInput("");
}}
onChange={handleChange}
type="text"
value={todoInput}
/>
<button
onClick={() => {
props.onAdd(todoInput);
setTodoInput("");
}}
>
<span>Add</span>
</button>
</div>
);
}

export default InputArea;

这是我的 todoTask 组件:

import React from "react";

function ToDoTask(props) {
return (
<div
onClick={() => {
props.onChecked(props.id);
}}
>
<li>{props.text}</li>
</div>
);
}

export default ToDoTask;

最佳答案

如果目标是在按下“enter”时清除输入,那么我建议使用表单元素。只要只有一个输入,然后在聚焦时按回车键就会提交表单。使用表单的提交处理程序调用 onAdd 回调并重置本地 todoInput 状态。

输入区域

function InputArea({ onAdd }) {
const [todoInput, setTodoInput] = useState("");

const submitHandler = (e) => {
e.preventDefault();
if (todoInput) {
onAdd(todoInput);
setTodoInput("");
}
};

function handleChange(event) {
const { value } = event.target;
setTodoInput(value);
}

return (
<form onSubmit={submitHandler}>
<input onChange={handleChange} type="text" value={todoInput} />
<button type="submit">
<span>Add</span>
</button>
</form>
);
}

演示

function InputArea({ onAdd }) {
const [todoInput, setTodoInput] = React.useState("");

const submitHandler = (e) => {
e.preventDefault();
if (todoInput) {
onAdd(todoInput);
setTodoInput("");
}
};

function handleChange(event) {
const { value } = event.target;
setTodoInput(value);
}

return (
<form onSubmit={submitHandler}>
<input onChange={handleChange} type="text" value={todoInput} />
<button type="submit">
<span>Add</span>
</button>
</form>
);
}

function ToDoTask(props) {
return (
<div
onClick={() => {
props.onChecked(props.id);
}}
>
<li>{props.text}</li>
</div>
);
}

function App() {
const [todoTasks, setTodoTasks] = React.useState([]);

function addTask(todoInput) {
setTodoTasks((prevTodoTasks) => {
return [...prevTodoTasks, todoInput];
});
}

function deleteTodoTask(id) {
setTodoTasks((prevTodoTasks) => {
return prevTodoTasks.filter((task, i) => {
return i !== id;
});
});
}

return (
<div className="container">
<div className="heading">
<h1>To-Do List</h1>
</div>
<div className="form">
<InputArea onAdd={addTask} />
</div>
<div>
<ul>
{todoTasks.map((todoTasks, i) => (
<ToDoTask
key={i}
id={i}
text={todoTasks}
onChecked={deleteTodoTask}
/>
))}
</ul>
</div>
</div>
);
}

const rootElement = document.getElementById("root");
ReactDOM.render(
<React.StrictMode>
<App />
</React.StrictMode>,
rootElement
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/17.0.2/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/17.0.2/umd/react-dom.production.min.js"></script>
<div id="root" />

关于reactjs - 输入字段未删除 React,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69670232/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com