Integer input with increment and decrement buttons.

Global use

  • npm install
npm install --save vue-integer-plusminus
  • import components
import { IntegerPlusminus } from 'vue-integer-plusminus'
  • declare use or imported components in your vue script
export default {
    components: { IntegerPlusminus },
    methods: ...
  • Use components as described below


Integer plus/minus

<integer-plusminus :min="ipm_min"
    <p>Your value is</p>
    {{ ipm_value }}
    <template slot="decrement">{{ ipm_slot_decr }}</template>
    <template slot="increment">{{ ipm_slot_incr }}</template>
Prop Type Note
min number minimum possible value. Cannot decrement lower. Default is 0
max number maximum possible value. Cannot increment over. Default is undefined
step number Incremental step. Must be greater than 0. Default is 1
vertical Boolean Use vertical layout. Default is false

This component provide 3 slots

  • Default slot is the middle part when value is usually displayed
  • 'increment' slot is used for increment button.
    Usually on right for horizontal layout,
    or top for vertical layout.
  • 'decrement' slot is used for decrement button.
    Usually on left for horizontal layout,
    or bottom for vertical layout.

Style could be overwritten using !important css keyword

.int-input-increment {
    background: #5CB85C !important;


  • 'input' on value change
  • 'ipm-increment' on value increment
  • 'ipm-decrement' on value decrement