4

嗨,我正在使用 jQuery 创建一个输入数字增量,但没有成功,请您检查我的代码并给我适当的指导

在这里查看演示

HTML

<div class="sp-quantity">
    <div class="sp-minus fff"> <a class="ddd" href="#">-</a></div>
    <div class="sp-input">
        <input type="text" class="quntity-input" value="1">
    </div>
    <div class="sp-plus fff"> <a class="ddd" href="#">+</a></div>
</div>

JS

$(".ddd").on("click", function () {

    var $button = $(this);
    var oldValue = $button.parent().find("input .quntity-input").val();

    if ($button.text() == "+") {
        var newVal = parseFloat(oldValue) + 1;
    } else {
        // Don't allow decrementing below zero
        if (oldValue > 0) {
            var newVal = parseFloat(oldValue) - 1;
        } else {
            newVal = 0;
        }
    }

    $button.parent().find("input .quntity-input").val(newVal);

});
4

3 回答 3

11

用于查找输入的选择器不正确。.quntity-input.sp-quantityDOM 中按钮上方两层的子级,因此您需要使用closest()选择器,而不是parent. 试试这个:

$(".ddd").on("click", function () {

    var $button = $(this);
    var oldValue = $button.closest('.sp-quantity').find("input.quntity-input").val();

    if ($button.text() == "+") {
        var newVal = parseFloat(oldValue) + 1;
    } else {
        // Don't allow decrementing below zero
        if (oldValue > 0) {
            var newVal = parseFloat(oldValue) - 1;
        } else {
            newVal = 0;
        }
    }

    $button.closest('.sp-quantity').find("input.quntity-input").val(newVal);

});

示例小提琴

您还可以简化代码:

$(".ddd").on("click", function() {
  var $button = $(this);
  var $input = $button.closest('.sp-quantity').find("input.quntity-input");
  $input.val((i, v) => Math.max(0, +v + 1 * $button.data('multi')));
});
.sp-quantity div { display: inline; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="sp-quantity">
  <div class="sp-minus fff"><a class="ddd" href="#" data-multi="-1">-</a></div>
  <div class="sp-input">
    <input type="text" class="quntity-input" value="1" />
  </div>
  <div class="sp-plus fff"><a class="ddd" href="#" data-multi="1">+</a></div>
</div>

于 2013-10-25T08:53:54.427 回答
3

您的输入选择器应该是

$button.closest('.sp-quantity').find("input.quntity-input")

演示:小提琴

于 2013-10-25T08:50:28.263 回答
2

你是这个意思吗?

在这里提琴

    $('.sp-plus').on('click', function(){
        var oldVal = $('input').val();
        var newVal = (parseInt($('input').val(),10) +1);
      $('input').val(newVal);
    });

    $('.sp-minus').on('click', function(){
        var oldVal = $('input').val();
        if (oldVal > 0)
        {
            var newVal = (parseInt($('input').val(),10) -1);
        }
        else
        {
            newVal = 0;
        }
        var newVal = (parseInt($('input').val(),10) -1);
        $('input').val(newVal);
    });
于 2013-10-25T08:56:43.583 回答