import { useRef, useState } from 'react' import Input from '../../UI/Input' import classes from './MealItemForm.module.css' export default function MealItemForm(props) { const [amountIsValid, setAmountIsValid] = useState(true) const amountInputRef = useRef() const submitHandler = event => { event.preventDefault() const enteredAmount = amountInputRef.current.value const enteredAmountNumber = +enteredAmount if (enteredAmount.trim().length === 0 || enteredAmountNumber < 1 || enteredAmountNumber > 20) { setAmountIsValid(false) return } props.onAddToCart(enteredAmountNumber) }
Intenté agregar una función después de submitHandler para deshabilitar el botón cuando el número de cantidad ingresado> 20, ¡pero no pude hacerlo funcionar!
return ( <form className={classes.form} onSubmit={submitHandler}> <Input ref={amountInputRef} label='Amount' input={{ id: 'amount_' + props.id, type: 'number', min: '1', max: '20', step: '1', defaultValue: '1' }} /> {/* Two curly braces: one for embedding javascript expression and the other one is there because the value is object */}
Quiero deshabilitar este botón cuando la cantidad ingresada> 20, ¡ayúdenme!
<button>+ Add</button> {!amountIsValid && <p>Please enter a valid amount(1~20)</p>} </form> ) }
Necesitas usar el atributo disabled
del button
<button disabled={enteredAmountNumber > 20}>Enter Amount</button>
Código basado en tu comentario
import { useRef, useState } from 'react' import Input from '../../UI/Input' import classes from './MealItemForm.module.css' export default function MealItemForm(props) { const [amountIsValid, setAmountIsValid] = useState(true) const amountInputRef = useRef() const submitHandler = event => { event.preventDefault() const enteredAmount = amountInputRef.current.value const enteredAmountNumber = +enteredAmount if (enteredAmount.trim().length === 0 || enteredAmountNumber < 1 || enteredAmountNumber > 20) { setAmountIsValid(false) return } props.onAddToCart(enteredAmountNumber) } return ( <form className={classes.form} onSubmit={submitHandler}> <Input ref={amountInputRef} label='Amount' input={{ id: 'amount_' + props.id, type: 'number', min: '1', max: '20', step: '1', defaultValue: '1' }} /> {/* Two curly braces: one for embedding javascript expression and the other one is there because the value is object */} <button disabled={!amountIsValid}>+ Add</button> {!amountIsValid && <p>Please enter a valid amount(1~20)</p>} </form> ) }
ACTUALIZAR basado en tu comentario
DEMO DE TRABAJO
import "./styles.css"; import react, { useState } from "react"; export default function App() { const [clickCount, setClickCount] = useState(0); return ( <div className="App"> <h1>Hello CodeSandbox</h1> <h2>Start editing to see some magic happen!</h2> <button disabled={clickCount >= 20} onClick={() => { setClickCount((clickCount) => clickCount + 1); }} > {clickCount === 0 ? `Click Me` : `You clicked ${clickCount} times`}{" "} </button> </div> ); }