2016-11-21 94 views
-5

如果一個按鈕有三個增量,我的頁面上有多個增加(+/-)購物車按鈕,那麼應該禁用所有剩餘按鈕來增加和減少。disable +減去添加按鈕

<div class="pull-right"><span class="desc_room_price">EUR 80.50</span> 
    <span class="input-group __newbtn"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __minusbtn" data-type="minus" data-field="hr_sec_b[1]"> 
       <span class="minus_btn_a"></span> 
       </button> 
      </span> 
      <input type="text" name="hr_sec_b[1]" class="form-control input-number" value="0" min="0" max="100"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __plusbtn" data-type="plus" data-field="hr_sec_b[1]"> 
        <span class="plus_btn_a"></span> 
       </button> 
      </span> 
     </span> 
</div> 

<div class="pull-right"><span class="desc_room_price">EUR 80.50</span> 
    <span class="input-group __newbtn"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __minusbtn" data-type="minus" data-field="hr_sec_b[1]"> 
       <span class="minus_btn_a"></span> 
       </button> 
      </span> 
      <input type="text" name="hr_sec_b[1]" class="form-control input-number" value="0" min="0" max="100"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __plusbtn" data-type="plus" data-field="hr_sec_b[1]"> 
        <span class="plus_btn_a"></span> 
       </button> 
      </span> 
     </span> 
</div> 

    $('.btn-number').click(function(e){ 
     e.preventDefault(); 

     var fieldName = $(this).attr('data-field'); 
     var type  = $(this).attr('data-type'); 
     var input = $("input[name='"+fieldName+"']"); 
     var currentVal = parseInt(input.val()); 
     if (!isNaN(currentVal)) { 
      if(type == 'minus') { 
       var minValue = parseInt(input.attr('min')); 
       if(!minValue) minValue = 0; 
       if(currentVal > minValue) { 
        input.val(currentVal - 1).change(); 
       } 
       if(parseInt(input.val()) == minValue) { 
        $(this).attr('disabled', true); 
       } 

      } else if(type == 'plus') { 
       var maxValue = parseInt(input.attr('max')); 
       if(!maxValue) maxValue = 9999999999999; 
       if(currentVal < maxValue) { 
        input.val(currentVal + 1).change(); 
       } 
       if(parseInt(input.val()) == maxValue) { 
        $(this).attr('disabled', true); 
       } 

      } 
     } else { 
      input.val(0); 
     } 
    }); 

默認情況下會啓用所有按鈕。 什麼是問題,請告訴我。

回答

1

的問題是:

  • 兩個輸入有相同的名稱:hr_sec_b[1]
  • 所有按鈕具有相同data-field="hr_sec_b[1]"
  • 缺少+和 - 按鈕標籤。
  • 固定按鈕在達到最小/最大值時禁用/啓用。

Working JSFiddle example

更正HTML

<div class="pull-right"><span class="desc_room_price">EUR 80.50</span> 
    <span class="input-group __newbtn"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __minusbtn" data-type="minus" data-field="hr_sec_b[0]"> 
       <span class="minus_btn_a">-</span> 
       </button> 
      </span> 
      <input type="text" name="hr_sec_b[0]" class="form-control input-number" value="0" min="0" max="5"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __plusbtn" data-type="plus" data-field="hr_sec_b[0]"> 
        <span class="plus_btn_a">+</span> 
       </button> 
      </span> 
     </span> 
</div> 

<div class="pull-right"><span class="desc_room_price">EUR 80.50</span> 
    <span class="input-group __newbtn"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __minusbtn" data-type="minus" data-field="hr_sec_b[1]"> 
       <span class="minus_btn_a">-</span> 
       </button> 
      </span> 
      <input type="text" name="hr_sec_b[1]" class="form-control input-number" value="0" min="0" max="5"> 
      <span class="input-group-btn"> 
       <button type="button" class="btn btn-number __plusbtn" data-type="plus" data-field="hr_sec_b[1]"> 
        <span class="plus_btn_a">+</span> 
       </button> 
      </span> 
     </span> 
</div> 

修正的JavaScript

$('.btn-number').click(function(e){ 
    e.preventDefault(); 

    var fieldName = $(this).attr('data-field'); 
    var type  = $(this).attr('data-type'); 
    var input = $("input[name='"+fieldName+"']"); 
    var reverseInput = $("button[data-field='" + fieldName + "'][data-type!='" + type + "']"); 
    var currentVal = parseInt(input.val()); 

    if (!isNaN(currentVal)) { 
     if(type == 'minus') { 
      $(reverseInput).attr('disabled', false); 
      var minValue = parseInt(input.attr('min')); 
      if(!minValue) minValue = 0; 
      if(currentVal > minValue) { 
       input.val(currentVal - 1).change(); 
      } 
      if(parseInt(input.val()) == minValue) { 
       $(this).attr('disabled', true); 
      } 
     } else if(type == 'plus') { 
      $(reverseInput).attr('disabled', false); 
      var maxValue = parseInt(input.attr('max')); 
      if(!maxValue) maxValue = 9999999999999; 
      if(currentVal < maxValue) { 
       input.val(currentVal + 1).change(); 
      } 
      if(parseInt(input.val()) == maxValue) { 
       $(this).attr('disabled', true); 
      } 
     } 
    } else { 
     input.val(0); 
    } 
});