Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/d-asensio/use-controlled-input-number

React hook to turn numeric input behavior into pretty much what you expect
https://github.com/d-asensio/use-controlled-input-number

Last synced: 3 months ago
JSON representation

React hook to turn numeric input behavior into pretty much what you expect

Awesome Lists containing this project

README

        

# use-controlled-input-number

*React hook to turn numeric input behavior into pretty much what you expect*

[![npm version](https://badge.fury.io/js/use-controlled-input-number.svg)](https://badge.fury.io/js/use-controlled-input-number)

While it is not obvious at first glance, numeric inputs are not simple. Especially if you want to use the value that is typed in to calculate something, since **they return a string instead of a number**.

This hook is intended to solve this problem in the easiest possible way, giving you all the control over the input, but making it behave as you would expect (always returning a number).






Example without hook


Example with hook




> You can find these examples in [codesandbox](https://codesandbox.io/s/example-1-d0fny?file=/src/App.js)

## Installation

```bash
yarn add use-controlled-input-number
```

## Usage

This is an example of use for this hook:

```javascript
function ControlledInput () {
const [value, setValue] = useState(1)

const inputProps = useControlledInputNumber({
value, // The value will always be of type number
onChange: setValue
})

return (

)
}
```

## Related projects

- [use_stepper](https://github.com/wKovacs64/use-stepper): If you want a hook that fully controls the behavior of the input.