使用表单数据执行计算并将其解析回表单

时间:2013-10-02 13:14:39

标签: javascript php jquery mysql forms

我是javascripting的总菜鸟,但我有一个很好的问题需要解决。

我有一个从数据库接收数据的表单。

我写了一个非常简单的javascript,它本身执行我希望它做的计算。 但是如何将计算出的值返回到表单中。我想使用onkeyup,以便在发送表单之前更新数据。

此时我只有表单和单独的javascript。但我不知道如何让它们一起工作。我知道javascript中的document.write语句在表单中不起作用。这个,我只是用来构建和检查我的计算器。

只要填写impru_rest值,就必须开始计算。并且必须将impru_dobanda和/或impru_sold的新值发回表单。

有什么想法吗?

这是表格的一部分

<?php 
    // create form according to existing loan/interest
    echo '<td><div align="center"><input type="text" size="11" name="impru_acc" value = '.$impru_acc.'></div></td>';
    echo '<td><div align="center"><input type="text" size="11" name="impru_rest" onkeyup= value = ""></div></td>';
    echo '<td><div align="center"><input type="text" size="11" name="impru_sold" value = '.$impru_sold.'></div></td>';
    echo '<td><div align="center"><input type="text" size="11" name="impru_dobanda" value = '.$impru_dobanda.'></div></td>';    
>?

这是计算

<script type=\"text/javascript\">

var impru_acc = ".$impru_acc.";
var impru_dobanda = ".$impru_dobanda.";
var impru_rest = ".$impru_rest.";
var impru_sold = ".$impru_sold.";

if (impru_dobanda>0) {
    var difference = impru_dobanda-impru_rest;
    } else {
        var difference = 0;
        }

if (difference > 0) {
    impru_dobanda = impru_dobanda - impru_rest;
    document.write(impru_sold);
    document.write(impru_dobanda); 
    }

if (difference < 0) {
    impru_sold = difference + impru_sold;
    impru_dobanda = 0;
    document.write(impru_sold);
    document.write(impru_dobanda);
    }

if (difference == 0) {
    impru_dobanda = 0;
    var impru_sold=impru_sold-impru_rest;
    document.write(impru_sold);
    document.write(impru_dobanda);
}
</script>

在Allen123和tinyByte的帮助下,我得到了这个,但它没有做任何事情:

我现在在标题中添加了jquery注释。

我可能在这个功能中犯了错误,但现在似乎没有任何事情发生。我猜这个脚本不能影响表单中的值 这就是我所拥有的。我做错了什么?

<?php
            // create form according to existing loan/interetest
            echo '<td><div align="center"><input type="text" size="11" name="impru_acc" value = '.$impru_acc.'></div></td>';
            echo '<td><div align="center"><input type="text" size="11" name="impru_rest" onkeyup=calculateAll(); value = ""></div></td>';
            echo '<td><div align="center"><input type="text" size="11" name="impru_sold" value = '.$impru_sold.'></div></td>';
            echo '<td><div align="center"><input type="text" size="11" name="impru_dobanda" value = '.$impru_dobanda.'></div></td>';    
    ?>      
            <script>
        function calculateAll(){ 
        var impru_acc = $('input[name="impru_acc"]').val();
        var impru_dobanda = $('input[name="impru_dobanda"]').val();
        var impru_rest = $('input[name="impru_rest"]').val();
        var impru_sold = $('input[name="impru_sold"]').val();

        if (impru_dobanda>0) {
            var difference = impru_dobanda-impru_rest;
            } else {
                var difference = 0;
                }
            if (difference > 0) {
                impru_dobanda = impru_dobanda - impru_rest;
                }
            if (difference < 0) {
                impru_sold = difference + impru_sold;
                impru_dobanda = 0;
                }
            if (difference == 0) {
                impru_dobanda = 0;
                var impru_sold=impru_sold-impru_rest;
            }
        }
    $(document).ready(function(){
       $('input').change(function(){
          calculateAll();
       });
    });

3 个答案:

答案 0 :(得分:1)

在函数中编写计算并在焦点输出时触发或更改,如下所示:

$('input').change(function(){
   calculateAll();
});

更新: set 1:在标题中包含一个缩小的jquery,如:

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>

然后在脚本标记()中使用上面的代码。如果你把它放在html标记的末尾会更好。

不要忘记将所有jQuery代码放入:

<script>
function calculateAll(){
   //implement your logic here 
   var value1 = $('input[name="somename"]').val();
    .
    .
    .
}
$(document).ready(function(){
   $('input').change(function(){
      calculateAll();
   });
});
</script>

答案 1 :(得分:0)

    <script type=\"text/javascript\">

    $('input').blur(function()
    {
          doCalculations();
    });


   function doCalculations()
   {

        var impru_acc = ".$impru_acc.";
        var impru_dobanda = ".$impru_dobanda.";
        var impru_rest = ".$impru_rest.";
        var impru_sold = ".$impru_sold.";

        if (impru_dobanda>0) {
            var difference = impru_dobanda-impru_rest;
            } else {
                var difference = 0;
                }

        if (difference > 0) {
            impru_dobanda = impru_dobanda - impru_rest;
            document.write(impru_sold);
            document.write(impru_dobanda); 
            }

        if (difference < 0) {
            impru_sold = difference + impru_sold;
            impru_dobanda = 0;
            document.write(impru_sold);
            document.write(impru_dobanda);
            }

        if (difference == 0) {
            impru_dobanda = 0;
            var impru_sold=impru_sold-impru_rest;
            document.write(impru_sold);
            document.write(impru_dobanda);
        }
      }   

    </script>

希望这会对你有帮助......

答案 2 :(得分:0)

所有,我找到了一个很好的工作方式。 在发布我的问题和这个答案之间的时间里,我开始学习javascripting。不太远,但它给了我一些尤里卡时刻。

表单现在由此代码组成,并从数据库中获取其值:

echo '<input type="text" size="11" name="impru_acc" id="impru_acc" value = '.$impru_acc.'>';
echo '<input type="text" size="11" name="impru_rest" id="impru_rest" onchange="calculateAll(this.value)" value = "">';
echo '<input type="text" size="11" name="impru_sold" id="impru_sold" value = '.$impru_sold.'>';
echo '<input type="text" size="11" name="impru_dobanda" id="impru_dobanda"  value = '.$impru_dobanda.'>';   

我制作了一个单独的calculateAll.js文件,并在我的header.html文件中调用它。

在我的问题中,calculateAll.js基于我的脚本,但现在已完成,包括将值解析回表单。代码包括:

function calculateAll(){ 
var form = document.forms["fisa"];
var impruDobandaValue = form.elements["impru_dobanda"];
var impruRestValue = form.elements["impru_rest"];
var impruSoldValue = form.elements["impru_sold"];

var impruDobanda = parseInt(impruDobandaValue.value);
var impruRest = parseInt(impruRestValue.value);
var impruSold = parseInt(impruSoldValue.value);

if (impruDobanda > 0) {
    var difference = impruDobanda - impruRest;
    } else {
        var difference = 0;
        }
    if (difference > 0) {
        impruDobanda = impruDobanda - impruRest;
        return theForm.elements["impru_dobanda"].value = impruDobanda;
        } else if (difference < 0) {
        impruSold = difference + impruSold;
        impruDobanda = 0;
        return form.elements["impru_dobanda"].value = impruDobanda, 
            form.elements["impru_sold"].value = impruSold;

        } else if (difference == 0) {
        impruDobanda = 0;
        var impruSold = impruSold - impruRest;
        return form.elements["impru_dobanda"].value = impruDobanda, 
            form.elements["impru_sold"].value = impruSold;
        }

    }

但我遇到了一个小问题。如果输入错误,表单不会使用原始值,而是从更改的值重新计算。这是合乎逻辑的。为了解决这个问题,我为表单中的impru_rest字段创建了一个重置​​按钮。它重置该字段并恢复表单中impru_sold和impru_dobanda值的原始值。之后可以进行修正。我认为最好用PHP编写代码

<?php echo "<input type=\"button\" value=\"Reset\" onclick=\"var reset = this.form.elements['impru_rest']; reset.value = reset.defaultValue; this.form.impru_dobanda.value=".$impru_dobanda."; this.form.impru_sold.value=".$impru_sold.";\">"
?>

总而言之,它花了我一点时间,但我想和你分享我的发现。

所有回复的人,谢谢你的帮助!

麦克