Как получить общую стоимость динамически созданных строк?

#javascript #jquery #laravel-5

#javascript #jquery #laravel-5

Вопрос:

Я хочу просуммировать цену всех динамически созданных строк и отобразить в поле ввода total..Я пробовал некоторые вещи, но у меня ничего не получалось.Я опубликовал свой сценарий и изображение, которое объясняет, как это должно работать. Все работает и сохраняется в базе данных, просто требуется общее количество всех элементов. Пожалуйста, смотрите изображение для более четкой концепции. Общая сумма 1-й строки сохраняется в целом, но не работает для динамически созданных строк.

Изображение: Это должно работать следующим образом

HTML:

    <div class="form-group">
     <label>Total</label>
      <input readonly type="text" id="total_amount" class="form-control"
       name="total_amount">
    </div>
  

Скрипт:

  <script>
    var counterr = 1;
    $(document).ready(function () {

        $('#unit_price,#item_quantity').change(function () {
            // alert();
            var unitPrice = $('#unit_price').val();
            // console.log(unitPrice);
            var quantity = $('#item_quantity').val();
            // console.log(quantity);

            var total = (unitPrice * quantity).toFixed(0);

            $('#total_price').val(total);
            $('#total_amount').val(total);

        });


        // Input Fields


        var maxField = 100; //Input fields increment limitation
        var addButton = $('#add_button'); //Add button selector
        var wrapper = $('.field_wrapper'); //Input field wrapper

        $(addButton).click(function (e) {
            e.preventDefault();
            counterr  ;
            //Check maximum number of input fields
            if (counterr < maxField) {
                fieldHTML = makeNewRow(counterr);
                $(wrapper).append(fieldHTML); //Add field html
                // $('#department-' counterr).select2();

                // console.log("Unit price", counterr);
                $('.unit_price'   counterr).change(function () {
                    // console.log("hello");
                    var unitPrice = $('.unit_price'   counterr).val();
                    // console.log(unitPrice);
                    var quantity = $('#item_quantity'   counterr).val();
                    // console.log(quantity);

                    var total = (unitPrice * quantity).toFixed(0);

                    $('#total_price'   counterr).val(total);


                     $('#total_price').each(function() {
                    subtotal  = parseFloat($(this).val());
                    console.log('test',subtotal);
                });
                 $('#total_amount').val(subtotal);

                });


            }

        });


        //Once remove button is clicked
        $(wrapper).on('click', '.remove_button', function (e) {
            e.preventDefault();
            $(this).parent('#newrow').remove(); //Remove field html
            counterr = counterr--; //Decrement field counter
        })


    });

    function makeNewRow(counterr) {

        return '<div class="row" id="newrow">'  
            '<div class="col-md-4">'  
            '<div class="form-group">'  
            '<select onChange="getPurchasePrice(this.value);" style="background-color: #f5f6f9" id="item_name'   counterr   '" class="form-control dep"'  
            'placeholder="Enter Item" name="testing[]"'   '>'  
            '<option value = "">Select Item</option>'   '>'  
            '@foreach($items as $item)'   '>'  
            '<option value = "{{$item->id}}">{{$item->item_name}}</option>'   '>'  
            '@endforeach'   '>'  
            '</select>'  
            '</div>'  
            '</div>'  
            '<div class="col-md-2">'  
            '<div class="form-group">'  
            '<input style="background-color: #f5f6f9" type="number" id="item_quantity'   counterr   '" class="form-control"'  
            'placeholder="Enter.." name="testing[]"'   '>'  
            '</div>'  
            '</div>'  
            '<div class="col-md-2">'  
            '<div class="form-group">'  
            '<input style="background-color: #f5f6f9" type="number" id="unit_price'   counterr   '" class="unit_price'   counterr   ' form-control"'  
            'placeholder="Enter.." name="testing[]"'   '>'  
            '</div>'  
            '</div>'  
            '<div class="col-md-3">'  
            '<div class="form-group">'  
            '<input value="0" style="background-color: #f5f6f9" disabled type="text" id="total_price'   counterr   '" class="form-control"'  
            'placeholder="Total" name="testing[]"'   '>'  
            '</div>'  
            '</div>'  
            '<a style="height:40px;margin-left:25px" href="javascript:void(0);" class="btn btn-danger remove_button">X</a>'  
            '</div>'; //New input field html
    }

    /*function removeDiv(no){
        $("#testingrow-" no).remove();
        x--;
    }*/


</script>
  

Комментарии:

1. пожалуйста, создайте рабочую копию и попытался запустить, но ничего не получилось

2. Вы используете имя элемента управления ‘total_price’ внутри вашего скрипта вместо HTML-элемента управления ‘total_amount’.

3. @mgsdew total_price — это общее количество элементов, где total_amount — это сумма всех элементов.

4. @brk общее количество 1-го элемента сохраняется в целом, но не работает для динамически созданных строк.

5. Затем объявите глобальную переменную с именем, подобным ‘Промежуточный итог’. Назначьте свое общее значение внутри лайков, промежуточный итог = итого; и в конце вашей функции назначьте промежуточное значение лайков, $(‘#total_price’).val(промежуточный итог);

Ответ №1:

Добавьте функцию для пересчета общей суммы ‘recallGrandTotal’

 var recalcGrandTotal = function() {
    var grandTotal = 0; // Declare a var to hold the grand total
    $("[id^=total_price]").each(function() { // Find all elements with an id that starts with 'total_price'
        grandTotal  = parseInt($(this).val()); // Add the value of the 'total_price*' field to the grand total
      })
  $('#total_amount').val(grandTotal); // append grand total amount to the total field
}
  

Затем подключите эту функцию к функции пересчета «общей цены»:
Найти

 $('#total_price'   counterr).val(total);
  

Добавить после:

 recalcGrandTotal();
  

Чтобы вычесть из общего итога при удалении элемента, подключите эту функцию к функции удаления элемента. Найти:

 counterr = counterr--; //Decrement field counter
  

Добавить после:

 recalcGrandTotal();
  

Комментарии:

1. Также подключите эту функцию к функции удаления. Найти: counterr = counterr—; добавить после: recallGrandTotal();

2. Я сталкиваюсь с одной проблемой, когда я создаю 3 строки, а затем, когда я изменяю количество и цену за единицу 2-й строки, общая цена не меняется… Если вы можете исправить эту проблему, пожалуйста, сделайте .. в противном случае все в порядке. Работает, когда я редактирую 1-ю и последнюю строку..

3. @DaniyalMughal Я считаю, что это связано с дублированием идентификаторов, вы должны заменить их классами.