2017-04-17 92 views
1

我想在垂直對齊中間的輸入文本框旁邊放置兩個按鈕。下面是我做的,到目前爲止:輸入文本字段旁邊的按鈕下方的按鈕

jQuery(document).ready(function($) { 
 
    //plugin bootstrap minus and plus 
 
    //http://jsfiddle.net/laelitenetwork/puJ6G/ 
 
    $('.btn-number').click(function(e) { 
 
    e.preventDefault(); 
 

 
    fieldName = $(this).attr('data-field'); 
 
    type = $(this).attr('data-type'); 
 
    var input = $("input[name='" + fieldName + "']"); 
 
    var currentVal = parseFloat(input.val()); 
 
    if (!isNaN(currentVal)) { 
 
     if (type == 'minus') { 
 

 
     if (currentVal > input.attr('min')) { 
 
      input.val(currentVal - 0.5).change(); 
 
     } 
 
     if (parseFloat(input.val()) == input.attr('min')) { 
 
      $(this).attr('disabled', true); 
 
     } 
 

 
     } else if (type == 'plus') { 
 

 
     if (currentVal < input.attr('max')) { 
 
      input.val(currentVal + 0.5).change(); 
 
     } 
 
     if (parseFloat(input.val()) == input.attr('max')) { 
 
      $(this).attr('disabled', true); 
 
     } 
 

 
     } 
 
    } else { 
 
     input.val(0); 
 
    } 
 
    }); 
 
    $('.input-number').focusin(function() { 
 
    $(this).data('oldValue', $(this).val()); 
 
    }); 
 
    $('.input-number').change(function() { 
 

 
    minValue = parseFloat($(this).attr('min')); 
 
    maxValue = parseFloat($(this).attr('max')); 
 
    valueCurrent = parseFloat($(this).val()); 
 

 
    name = $(this).attr('name'); 
 
    if (valueCurrent >= minValue) { 
 
     $(".btn-number[data-type='minus'][data-field='" + name + "']").removeAttr('disabled') 
 
    } else { 
 
     alert('Sorry, the minimum value was reached'); 
 
     $(this).val($(this).data('oldValue')); 
 
    } 
 
    if (valueCurrent <= maxValue) { 
 
     $(".btn-number[data-type='plus'][data-field='" + name + "']").removeAttr('disabled') 
 
    } else { 
 
     alert('Sorry, the maximum value was reached'); 
 
     $(this).val($(this).data('oldValue')); 
 
    } 
 

 

 
    }); 
 

 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div class="center"> 
 
    <div class="input-group"> 
 
    <input type="text" name="quant[1]" class="form-control input-number" value="1" min="1" max="10"> 
 
    <ul class="input-group-btn"> 
 
     <li><button type="button" class="btn btn-default btn-number" disabled="disabled" data-type="minus" data-field="quant[1]"> 
 
\t \t \t \t <span class="glyphicon glyphicon-minus">-</span> 
 
\t \t \t </button></li> 
 
     <li><button type="button" class="btn btn-default btn-number" data-type="plus" data-field="quant[1]"> 
 
\t \t \t \t <span class="glyphicon glyphicon-plus">+</span> 
 
\t \t \t </button></li> 
 
    </ul> 
 
    </div> 
 
</div>

的代碼工作不錯,但我有一個定位的元素沒有運氣。

回答

2

像這樣的事情

ul.input-group-btn { 
    display: inline-block; 
    list-style: none; 
    padding: 0; 
    margin: 0; 
    vertical-align: middle; 
} 

jQuery(document).ready(function($) { 
 
    //plugin bootstrap minus and plus 
 
    //http://jsfiddle.net/laelitenetwork/puJ6G/ 
 
    $('.btn-number').click(function(e) { 
 
    e.preventDefault(); 
 

 
    fieldName = $(this).attr('data-field'); 
 
    type = $(this).attr('data-type'); 
 
    var input = $("input[name='" + fieldName + "']"); 
 
    var currentVal = parseFloat(input.val()); 
 
    if (!isNaN(currentVal)) { 
 
     if (type == 'minus') { 
 

 
     if (currentVal > input.attr('min')) { 
 
      input.val(currentVal - 0.5).change(); 
 
     } 
 
     if (parseFloat(input.val()) == input.attr('min')) { 
 
      $(this).attr('disabled', true); 
 
     } 
 

 
     } else if (type == 'plus') { 
 

 
     if (currentVal < input.attr('max')) { 
 
      input.val(currentVal + 0.5).change(); 
 
     } 
 
     if (parseFloat(input.val()) == input.attr('max')) { 
 
      $(this).attr('disabled', true); 
 
     } 
 

 
     } 
 
    } else { 
 
     input.val(0); 
 
    } 
 
    }); 
 
    $('.input-number').focusin(function() { 
 
    $(this).data('oldValue', $(this).val()); 
 
    }); 
 
    $('.input-number').change(function() { 
 

 
    minValue = parseFloat($(this).attr('min')); 
 
    maxValue = parseFloat($(this).attr('max')); 
 
    valueCurrent = parseFloat($(this).val()); 
 

 
    name = $(this).attr('name'); 
 
    if (valueCurrent >= minValue) { 
 
     $(".btn-number[data-type='minus'][data-field='" + name + "']").removeAttr('disabled') 
 
    } else { 
 
     alert('Sorry, the minimum value was reached'); 
 
     $(this).val($(this).data('oldValue')); 
 
    } 
 
    if (valueCurrent <= maxValue) { 
 
     $(".btn-number[data-type='plus'][data-field='" + name + "']").removeAttr('disabled') 
 
    } else { 
 
     alert('Sorry, the maximum value was reached'); 
 
     $(this).val($(this).data('oldValue')); 
 
    } 
 

 

 
    }); 
 

 
});
ul.input-group-btn { 
 
    display: inline-block; 
 
    list-style: none; 
 
    padding: 0; 
 
    margin: 0; 
 
    vertical-align: middle; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div class="center"> 
 
    <div class="input-group"> 
 
    <input type="text" name="quant[1]" class="form-control input-number" value="1" min="1" max="10"> 
 
    <ul class="input-group-btn"> 
 
     <li><button type="button" class="btn btn-default btn-number" disabled="disabled" data-type="minus" data-field="quant[1]"> 
 
\t \t \t \t <span class="glyphicon glyphicon-minus">-</span> 
 
\t \t \t </button></li> 
 
     <li><button type="button" class="btn btn-default btn-number" data-type="plus" data-field="quant[1]"> 
 
\t \t \t \t <span class="glyphicon glyphicon-plus">+</span> 
 
\t \t \t </button></li> 
 
    </ul> 
 
    </div> 
 
</div>

0

創建2周的div並使用float屬性把他們左右。

<div class="input-group"> 
<div id="leftdiv" style="float:left"> 
    <input type="text" name="quant[1]" class="form-control input-number" value="1" min="1" max="10"> 
</div> 
<div id="rightdiv" style="float:right;"> 
    <ul class="input-group-btn"> 
     <li> 
      <button type="button" class="btn btn-default btn-number" disabled="disabled" data-type="minus" data-field="quant[1]"> 
       <span class="glyphicon glyphicon-minus">-</span> 
      </button> 
     </li> 
     <li> 
      <button type="button" class="btn btn-default btn-number" data-type="plus" data-field="quant[1]"> 
       <span class="glyphicon glyphicon-plus">+</span> 
      </button> 
     </li> 
    </ul> 
</div>