我是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();
});
});
答案 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.";\">"
?>
总而言之,它花了我一点时间,但我想和你分享我的发现。
所有回复的人,谢谢你的帮助!
麦克