Неверный вызов ловушки, когда я устанавливаю значения из numpad, используя useChange - PullRequest
1 голос
/ 24 февраля 2020

Это мой компонент:

const pricePicker = ({
    step,
    precision,
    input,
    placeholder,
    label,
    theme,
    props,
    meta: { touched, error },
    ...rest
}) => {
/*In the FOLLOWING LINES from "function useChange(e)" to "return [value,change]"

is the error known as Invalid hook.
*/

    function useChange(e){
         const [value,setValue] = useState(0);

         function change(event){
             setValue(value => event.target.value);
         }
         return [value,change];
    }

    const handleBlur = (e) => {

        if (e.target.value === '0') e.target.value = '0'

    }


    const handleKeypress = (e)  => {
        const characterCode = e.key
        if (characterCode === 'Backspace') return

        const characterNumber = Number(characterCode)
        if (characterNumber < 0) {
              e.preventDefault()
        }
    }

    const myTheme = {
        fontFamily: 'Arial',
        textAlign: 'center',
        header: {
            primaryColor: '#263238',
            secondaryColor: '#f9f9f9',
            highlightColor: '#FFC107',
            backgroundColor: '#607D8B',
        },
        body: {
            primaryColor: '#263238',
            secondaryColor: '#32a5f2',
            highlightColor: '#FFC107',
            backgroundColor: '#f9f9f9',
        },
        panel: {
            backgroundColor: '#CFD8DC'
        }
    };


    return(
        <div className='form-group'> 

            <label forname={input.name}>{label}</label> <br />
            <NumPad.Number
                {...rest}
                step={0.1}
                precision={2}
                placeholder={!input.value ? 'Please, type a number' : input.value}
                selected={input.value ? new NumPad.Number(input.value) : null}
                onKeyDown={(changedVal) => handleKeypress(changedVal)}
                onBlur={(changedVal) => handleBlur(changedVal)}
                onChange={(changedVal) => useChange(changedVal)}


                className='form-control'


            />
            <div className='text-danger' style={{ marginBottom: '20px' }}>
                {touched && error}
            </div>
        </div>
    );
};

export default pricePicker;

Когда я выполняю этот блок кода:

function useChange(e){
    const [value,setValue] = useState(0);
    function change(event){
         setValue(value => event.target.value);
    }
    return [value,change];
}

У меня возникает следующая проблема:

Неверный вызов крюка. Хуки могут быть вызваны только внутри тела компонента функции. Это может произойти по одной из следующих причин: 1. У вас могут быть несовпадающие версии React и средства визуализации (например, React DOM). 2. Возможно, вы нарушаете правила хуков. 3. Возможно, у вас есть несколько копий React в то же самое приложение

Я перепробовал все способы, но кажется, что это невозможно. Я никогда не использовал хуки, и ранее я публиковал сообщения о чем-то похожем, но безуспешно. В предыдущем посте говорилось о том, что useState находится внутри pricePicker Функция не является ни функциональным компонентом, ни компонентом перехватчика при выполнении предыдущих строк кода, например:

const handleChange = (e) =>{
     // in the following line is the error.
     const[value, setValue] = useState(0);
}

Как я могу решить эту проблему? Мне нужно это исправить, но как? Я перепробовал все способы, но безуспешно.

Кто-нибудь знает, как я могу решить эту проблему? Это важно.

1 Ответ

0 голосов
/ 24 февраля 2020

Ошибка на самом деле довольно проста - зацепки могут использоваться только на верхнем уровне функциональных компонентов . В вашем конкретном примере вы не можете использовать useState внутри функции useChange.

Вместо этого сделайте что-то вроде:

const pricePicker = ({/*props go here*/
    const [value,setValue] = useState(0);
    // handler of input change
    const onChange = e => setValue(e.target.value);

    // the rest of the code can stay the same

   return <div className='form-group'> 
            <label forname={input.name}>{label}</label> <br />
            <NumPad.Number
                {...rest}
                step={0.1}
                precision={2}
                placeholder={!input.value ? 'Please, type a number' : input.value}
                selected={input.value ? new NumPad.Number(input.value) : null}
                onKeyDown={(changedVal) => handleKeypress(changedVal)}
                onBlur={(changedVal) => handleBlur(changedVal)}
                onChange={onChange} /* Here's we use the onChange handler */
                className='form-control'
            />
            <div className='text-danger' style={{ marginBottom: '20px' }}>
                {touched && error}
            </div>
    </div>;
}

...