problem with input type number

Hi guys, when the value of quantity is 0 and I enter 1 the input field display "01" while the quantity is 1. Can anyone help me explain why ? I'm using MUI. This case only occurs when I use type number. With type text, it worked
const [quantity, setQuantity] = useState(0);
const [stock, setStock] = useState(0);

const handleOnChangeQuantity = (
e: ChangeEvent<HTMLInputElement | HTMLTextAreaElement>
) => {
if (!e.target.value) return setQuantity(0);
if (+e.target.value > stock) return setQuantity(stock);
setQuantity(+e.target.value);
};

<TextFieldCustom
type="number"
fullWidth
value={quantity}
onChange={handleOnChangeQuantity}
className={styles["input-number"]}
inputProps={{ min: 0, max: stock }}
/>
const [quantity, setQuantity] = useState(0);
const [stock, setStock] = useState(0);

const handleOnChangeQuantity = (
e: ChangeEvent<HTMLInputElement | HTMLTextAreaElement>
) => {
if (!e.target.value) return setQuantity(0);
if (+e.target.value > stock) return setQuantity(stock);
setQuantity(+e.target.value);
};

<TextFieldCustom
type="number"
fullWidth
value={quantity}
onChange={handleOnChangeQuantity}
className={styles["input-number"]}
inputProps={{ min: 0, max: stock }}
/>
7 Replies
RAiDeRTuRbO
RAiDeRTuRbOβ€’7mo ago
Looks like you've fixed this now..? You appear to have changed the value={quantity} to value={quantity.toString()} now..? Did that fix the issue for you?
empty
emptyOPβ€’7mo ago
Yeah. But idk why
Chooβ™šπ•‚π•šπ•Ÿπ•˜
Did you originally have += instead of +? That would have concatenated the new value to the previous one. Changing that to a plus performs the unary plus operation of converting a string to a number.
empty
emptyOPβ€’7mo ago
No, I use plus operation to convert string to a number
MarkBoots
MarkBootsβ€’7mo ago
fyi, you can also use .valueAsNumber()
Tenkes
Tenkesβ€’7mo ago
Not a function. So just .valueAsNumber

Did you find this page helpful?