Home > Mobile >  React hook form only allow numbers greater than 0
React hook form only allow numbers greater than 0

Time:09-28

I'm using React Hook Form to make an input for height, weight and length. The value cannot be 0 - it has to be at least 1 or more. I tried different ways such as: pattern with regex, validate and more. But I am unable to figure out how to prevent the input field from letting the user type in '0' ( only as the first character ). I also tried type="number" and min="1" however it's not changing anything. Any ideas would be greatly appreciated.

                    <Input
                      {...form.register(`pallets.${index}.weight`, {
                        required: t('errors.emptyInput'),
                        pattern: {
                          value: /^[^1-9]/,
                          message: 'hello',
                        },
                        validate: (value) => {
                          return [/^[^1-9]/].every((pattern) => pattern.test(value))
                        },
                      })}
                      type='number'
                    />

It appears to me that pattern does not change anything. Only type= 'number' actually affects the way the input field works.

CodePudding user response:

<input
  type="number"
  {...register("test", {
    min: 1
  })}
/>

You can check the detailed usage from the documentation.

CodePudding user response:

You can take advantage of react useState hook to implement this functionality.

export default function App() {
  const [x, setX] = useState(null);
  const handleChange = e => {
    const value = e.target.value;
    if (!value || /^[1-9]\d*/.test(value))
      setX(e.target.value)
  }
  return (
    <div className="App">
      <input type="number" value={x} onChange={handleChange} />
    </div>
  );
}
  • Related