Как сделать автоматический расчет в динаме c несколько форм? - PullRequest
1 голос
/ 01 апреля 2020
function sum()
  {
  $(document).on('keyup', "*[data-field='unit'],*[data-field='unit_price']", function(e)
    {
    var unit      = document.getElementById('unit').value;
    var unitPrice = document.getElementById('unit_price').value;
    var result    = parseInt(unit) * parseInt(unitPrice);
    if (!isNaN(result)) 
      {
      document.getElementById('amount').value = result;
      }
    });
  }

p / s: это только функция в нормальном виде. но не Dynami c форма.

[редактировать?]

$('#unit, #price').on('input',function()
  {
  let qty   = parseInt($('#unit').val())
    , price = parseFloat($('#price').val())
    ;
  $('#amount').val((qty * price ? qty * price : 0).toFixed(2));
  });

1 Ответ

1 голос
/ 01 апреля 2020

Вы можете сделать это с помощью jQuery Плагин я пишу простой

Вы можете проверить это на этом:

$.fn.sum = function(options) {
    "use strict";
    var self = this;
    self.defaults = {
        unit          :   '[data-field="unit"]',
        unit_price    :   '[data-field="unit_price"]',
        result    		:   '[data-field="amount"]',
        onCalculate         : function(result){},
       
    };
    self.settings = $.extend({},self.defaults, options );
 
  	var unit_count = $(self).find('input'+self.settings.unit).length;
    var unit_price_count = $(self).find('input'+self.settings.unit_price).length;

    if(unit_count > 0 && unit_price_count > 0){
   
   var unit, unit_price=0, result=0;
   
   
    $($(self).find('input'+self.settings.unit_price)).bind('keyup', function(){
   
     	unit = $(this).closest('form').find('input'+self.settings.unit).val();
      unit_price = $(this).closest('form').find('input'+self.settings.unit_price).val();
      result = sum(unit, unit_price);
      self.settings.onCalculate(self, $(this), result);
      
   });
  
   $($(self).find('input'+self.settings.unit)).bind('keyup', function(){
   		unit = $(this).closest('form').find('input'+self.settings.unit).val();
      unit_price = $(this).closest('form').find('input'+self.settings.unit_price).val();
      result = sum(unit, unit_price);
      self.settings.onCalculate(self, $(this), result);
      
      
   });
   
   function sum(unit, unit_price){
  		var result = parseInt(unit) * parseInt(unit_price);
    if (!isNaN(result)) {
     return result;
    }
   }
   	
  }
    
    
}

$(document).ready(function(){
$('form').sum({
onCalculate: function(self, active, result){
	$(active).closest('form').find(self.settings.result).val(result);
	
	},
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form id="fff33">
<legend>
two
</legend>
<lable>unit</lable>
<input type="text" data-field='unit' id="unit22">
<br>
<lable>unit_price</lable>
<input type="text" data-field='unit_price' id="unit_price22">
<input type="text" data-field="amount" disabled>
</form>
<br>

<br><br>
<form id="fff">
<legend>
one
</legend>
<lable>unit</lable>
<input type="text" data-field='unit' id="unit">
<br>
<lable>unit_price</lable>
<input type="text" data-field='unit_price' id="unit_price">
<input type="text" data-field="amount" disabled>
</form>
<br><br>
...