Below code is working fine with button that is created in this code .but i also want to use the enter button to do same work .
<div className="input" >
<input
type="text"
placeholder="Type something..."
id="myinput"
onChange={(e) => setText(e.target.value)}
value={text}
/>
<div className="send">
{/* <img src={Attach} alt="attach" /> */}
<input
type="file"
style={{ display: "none" }}
id="file"
onChange={(e) => setImg(e.target.files[0])}
/>
<label htmlFor="file">
<img src={Attach} alt="img" />
</label>
<button onClick={handleSend}>Send</button>
</div>
</div>
how to achieve that?
Below code is working fine with button that is created in this code .but i also want to use the enter button to do same work .
<div className="input" >
<input
type="text"
placeholder="Type something..."
id="myinput"
onChange={(e) => setText(e.target.value)}
value={text}
/>
<div className="send">
{/* <img src={Attach} alt="attach" /> */}
<input
type="file"
style={{ display: "none" }}
id="file"
onChange={(e) => setImg(e.target.files[0])}
/>
<label htmlFor="file">
<img src={Attach} alt="img" />
</label>
<button onClick={handleSend}>Send</button>
</div>
</div>
how to achieve that?
Share Improve this question asked Dec 31, 2022 at 12:23 user15998452user15998452 1-
a click handler on a button element should automatically be fired when the user presses Enter (or Space) when the button is focused. Do you want it to fire when the user presses enter anywhere on the page? In that case you need to add an event listener to the
document
(in auseEffect
, and remove it in the cleanup). – Robin Zigmond Commented Dec 31, 2022 at 12:26
2 Answers
Reset to default 4Simply you can warp the input with the form
tag and you can use the onSubmit
function, In that case, onClick
and press enter
both will work.
const handleOnSubmit = () => {
// write your function here
}
<form onSubmit={handleOnSubmit} className="input">
<input
type="text"
placeholder="Type something..."
id="myinput"
onChange={(e) => setText(e.target.value)}
value={text}
/>
<div className="send">
{/* <img src={Attach} alt="attach" /> */}
<input
type="file"
style={{ display: 'none' }}
id="file"
onChange={(e) => setImg(e.target.files[0])}
/>
<label htmlFor="file">
<img src={Attach} alt="img" />
</label>
<button type="submit">Send</button>
</div>
</form>
Basically, there can be many ways to do so, you can use onKeyPress attribute to check if the pressed key is "Enter" and then run the same "handleSend" function.
<button
onClick={handleSend}
onKeyDown={e => e.key === 'Enter' ? handleSend:
''}>Send</button>
this query is already discussed in this thread. Here's a link!