<input type="number" min="0" max="2" step="0.50">
.quantity-buttons {
  display: flex;
  justify-content: space-between;
  background: #eee;
  border: 1px solid grey;
  height: 32px;
  width:200px;
}
.quantity-buttons input {
  border: none;
  background: transparent;
  width: 100%;
}
.quantity-buttons button {
  background-color: grey;
  border: none;
  min-width: 32px;
}
/**
  * Minus and Plus buttons to NUMBER type INPUTS
  */
		
// Select all INPUTS with type NUMBER
const inputNumber = document.querySelectorAll("input[type='number']");
inputNumber.forEach(function(item){
  // create wrapper container
  let wrapper = document.createElement('div');
  // add class to wrapper div
  wrapper.classList.add("quantity-buttons")
  // insert wrapper before item in the DOM tree
  item.parentNode.insertBefore(wrapper, item);
  // move item into wrapper
  wrapper.appendChild(item);
  
  // Inser plus and minus buttons
  item.insertAdjacentHTML('beforebegin', '<button type="button" class="minus-button">-</button>');
  item.insertAdjacentHTML('afterend', '<button type="button" class="plus-button">+</button>');
});

// Minus Button
const plusButton = document.querySelectorAll(".plus-button");
plusButton.forEach(function(btn) {
  btn.addEventListener('click', function(element){
    let inputNumber = this.previousElementSibling;
		inputNumber.stepUp();
		// trigger change event
    let change = new Event("change");
    inputNumber.dispatchEvent(change);
  })
})

// Minus Button
const minusButton = document.querySelectorAll(".minus-button");
minusButton.forEach(function(btn) {
  btn.addEventListener('click', function(element){
    let inputNumber = this.nextElementSibling;
		inputNumber.stepDown();
		// trigger change event
    let change = new Event("change");
    inputNumber.dispatchEvent(change);
  })
})
Run Pen

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.