在 React hooks 中获取输入值并打印
Get the input value in React hooks and print it
我正在尝试在屏幕上打印输入值,但每次输入新字符时它都会不断更新。
/*Import*/
import React, { useState } from "react";
import "./Search.scss";
/*Component*/
const Search = () => {
/*State*/
const [input, setInput] = useState("");
/*On Form Submit*/
return (
<>
<div className="Search">
<form onSubmit={(e) => e.preventDefault()} className="Search__form">
<input
value={input}
onChange={(e) => setInput(e.target.value)}
type="text"
placeholder=" Title, companies, expertise, or benefits"
style={{ fontFamily: "Arial, FontAwesome" }}
></input>
<button onclick={console.log(input)}>Search</button>
</form>
<h1>{input}</h1>
</div>
</>
);
};
/*Exprting*/
export default Search;
我只想在单击按钮后打印整个值
您在每次重新呈现时调用 console.log(input)
,而不是仅在单击时调用。将其转换为箭头函数,它应该可以执行您想要的操作。
<button onClick={()=>console.log(input)}>Search</button>
编辑:回答您的后续问题:您需要两个独立的状态变量:
/*Import*/
import React, { useState } from "react";
import "./Search.scss";
/*Component*/
const Search = () => {
/*State*/
const [input, setInput] = useState("");
// new state variable
const [submittedInput, setSubmittedInput] = useState("");
/*On Form Submit*/
return (
<>
<div className="Search">
<form onSubmit={(e) => e.preventDefault()} className="Search__form">
<input
value={input}
onChange={(e) => setInput(e.target.value)}
type="text"
placeholder=" Title, companies, expertise, or benefits"
style={{ fontFamily: "Arial, FontAwesome" }}
></input>
<button onClick={()=>setSubmittedInput(input)}>Search</button>
</form>
<h1>{submittedInput}</h1>
</div>
</>
);
};
我正在尝试在屏幕上打印输入值,但每次输入新字符时它都会不断更新。
/*Import*/
import React, { useState } from "react";
import "./Search.scss";
/*Component*/
const Search = () => {
/*State*/
const [input, setInput] = useState("");
/*On Form Submit*/
return (
<>
<div className="Search">
<form onSubmit={(e) => e.preventDefault()} className="Search__form">
<input
value={input}
onChange={(e) => setInput(e.target.value)}
type="text"
placeholder=" Title, companies, expertise, or benefits"
style={{ fontFamily: "Arial, FontAwesome" }}
></input>
<button onclick={console.log(input)}>Search</button>
</form>
<h1>{input}</h1>
</div>
</>
);
};
/*Exprting*/
export default Search;
我只想在单击按钮后打印整个值
您在每次重新呈现时调用 console.log(input)
,而不是仅在单击时调用。将其转换为箭头函数,它应该可以执行您想要的操作。
<button onClick={()=>console.log(input)}>Search</button>
编辑:回答您的后续问题:您需要两个独立的状态变量:
/*Import*/
import React, { useState } from "react";
import "./Search.scss";
/*Component*/
const Search = () => {
/*State*/
const [input, setInput] = useState("");
// new state variable
const [submittedInput, setSubmittedInput] = useState("");
/*On Form Submit*/
return (
<>
<div className="Search">
<form onSubmit={(e) => e.preventDefault()} className="Search__form">
<input
value={input}
onChange={(e) => setInput(e.target.value)}
type="text"
placeholder=" Title, companies, expertise, or benefits"
style={{ fontFamily: "Arial, FontAwesome" }}
></input>
<button onClick={()=>setSubmittedInput(input)}>Search</button>
</form>
<h1>{submittedInput}</h1>
</div>
</>
);
};