Задать вопрос
@jalilko05

Как сделать так чтобы в input нельзя было вводить меньше 5?

У меня есть инпут где пользователь должен вводить не меньше 5 но и не больше 50, как можно реализовать это? И ещё когда я удаляю всё значение из инупта то остаётся ноль так как начальное value у него null как показано в коде
const [ amount, setAmount ] = useState(null || '');

Как это исправить?
  • Вопрос задан
  • 161 просмотр
Подписаться 1 Простой 1 комментарий
Решения вопроса 2
firedragon
@firedragon
Не джун-мидл-сеньор, а трус-балбес-бывалый.
import React, { useState } from 'react';

export function App(props) {
  const [value, setValue] = useState( '');
  const [bg, setBg] = useState('red');
  const handleChange = event => {
    setValue(event.target.value);
    if(value.length < 5 || value.length>50){
      setBg('red')
    }
    else{
      setBg('')
    }
   
  };

  return (
    <div className='App'>
      <input
        type='text'
        value={value}
        onChange={handleChange}
        style={{  backgroundColor: bg}}
      />
      <pre>{value}</pre>
    </div>
  );
}
Ответ написан
@awenn2015
Веб-программист самоучка
Можно через событие onBlur валидировать

const Input = () => {
  const range = { min: 5, max: 50 }
  const [value, setValue] = useState<number | "">(range.min)

  function onBlurHandle(value: number) {
    if (value >= range.min && value < range.max) return;
    setValue(range.min)
  }

  return (
    <input
      type="number"
      value={value}
      onChange={({ target }) => setValue(target.value === "" ? "" : +target.value)}
      onBlur={({ target }) => onBlurHandle(+target.value)}
      min={range.min}
      max={range.max}
    />
  )
}
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
morsa
@morsa
Frontend-разработчик
Здравствуйте!
Элементу input можно добавить атрибуты:
minlength=count
maxlength=count

Пример
<input name="name" type="text" value="Shampoo" minlength="3" maxlength="20" required>
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы