jQuery复选框计算总值

时间:2015-11-19 15:22:59

标签: javascript php jquery checkbox

我要做的是显示每个所选复选框的总数,例如:如果我选择一个值为100的复选框,而选择另一个值为200的我得到300作为输出,如果我取消选择它将会总的来说。我尽我所能,但根本没有结果,需要一些帮助。

这高于html 我使用PHP,所以我可以更快地更改值

<?php 
    //basisprijs en titel  die erbij komen, Dit moet aangepast worden.
    $basisPrijs=
    array(
        array("titel" => 'template1', "prijs" => '100'),
        array("titel" => 'template2', "prijs" => '200'),
        array("titel" => 'template3', "prijs" => '300'),
        array("titel" => 'template4', "prijs" => '400')
    );
    //onderdelen en titel die erbij komen, Dit moet aangepast worden.
    $onderdelen=
    array(
        array("titel" => 'Table', "prijs" => '100'),
        array("titel" => 'Checkbox', "prijs" => '200'),
        array("titel" => 'List', "prijs" => '300'),
        array("titel" => 'Selectbox', "prijs" => '400')
    );
    $titel="Bereken tool";
    $check="Bestellen";
    ?>   

这是在头和Jquery

之后
 <body>
  <!-- <script type="text/javascript"></script> -->
  <div class="container">
    <div id="content">
      <h3><?php echo $titel; ?></h3>
      <form action="index.php" method="post">
        <div class="checkbox">
           <?php foreach($onderdelen as $key => $value)
           {echo "<div class='checkbox'>
           <label><input class='check' type='checkbox' value='".$onderdelen[$key]["prijs"]."' 
            name='".$onderdelen[$key]["titel"]."'>"
            .$onderdelen[$key]["titel"]."</label></div>"
                        ;}?>
          </div>
        </form>
      <div>
      <button type="button" class="btn btn-default"><?php echo $check; ?></button>
      <p id="output">output:</p>
    </div>
  </div>
</div> 
<script>
  $(document).ready(function() { 
            $(".check").change(function() {
               var prijs= this.checked ? this.value : '';
               $("#output").text(prijs); 
            });
        });   
 </script>

3 个答案:

答案 0 :(得分:2)

试试这个(我没试过,但这就是概念):

SELECT * FROM (
  SELECT
    ROW_NUMBER() OVER (ORDER BY key ASC) AS rownumber,
    columns
  FROM tablename
) AS foo
WHERE rownumber <= n

答案 1 :(得分:1)

您还可以通过附加div侦听器来侦听包装change上的复选框更改。 在处理程序中,将total设置为零,并使用类.check遍历所有已检查的输入,按值增加total,最后显示结果。

$('.checkbox').on('change', function () {
    var total = 0;
    $('.check:checked').val(function (idx, val) { // Iterates checked inputs only
        total += +val;
        return val;
    });
    $('#result').text(total);
});

A working demo at jsFiddle

那些需要多个复选框字段的人可以使用这个稍微修改过的代码:

function countTotal () {
    var total = 0;    
    $('#' + this.id + ' .check:checked').val(function (idx, val) {
        total += +val;
        return val;
    });
    $('#res' + this.id).text(total);
}

$('.checkbox').on('change', countTotal);

A working demo at jsFiddle

注意,现在包装div需要一个id。

答案 2 :(得分:0)

试试这个,

$(document).ready(function(){

        $(".check").change(function(){
            var tot = 0;
            $(".check:checked").each(function(){
               tot += parseInt($(this).val());              
            });
            $("#output").text(tot);
        });
});