对字段值求和(如果它们满足条件)



我正在尝试对许多字段值求和,但前提是满足与这些归档值相关的条件。例如:

我有一个包含多个数值字段的 PDF 表单。每个数字字段都附带一个状态选项。我只想添加相同状态的所有数字字段。这是我尝试并认为有效的代码,但似乎如果在先前添加的字段上更改了状态,它将无法工作。 例如,如果我添加字段 1、字段 2 和字段 4,因为它们的状态相同,但我返回并将 Field2 的状态更改为不同的状态,它将停止工作:

// field names
var cTotal1 = "Day1Pd1Total";
var cTotal2 = "Day1Pd2Total";
var cTotal3 = "Day1Pd3Total";
var cTotal4 = "Day1Pd4Total";
var cTotal5 = "Day1Pd5Total";
var cTotal6 = "Day1Pd6Total";
var cStatus1 = "Day1Pd1Status";
var cStatus2 = "Day1Pd2Status";
var cStatus3 = "Day1Pd3Status";
var cStatus4 = "Day1Pd4Status";
var cStatus5 = "Day1Pd5Status";
var cStatus6 = "Day1Pd6Status";
// get conditonal field values
var vStatus1 = this.getField(cStatus1).value;
var vStatus2 = this.getField(cStatus2).value;
var vStatus3 = this.getField(cStatus3).value;
var vStatus4 = this.getField(cStatus4).value;
var vStatus5 = this.getField(cStatus5).value;
var vStatus6 = this.getField(cStatus6).value;
// get field values base on condition
if(vStatus1 == "1"){
var vTotal1 = this.getField(cTotal1).value;
}else{
var vTotal1 = "";
}
if(vStatus2 == "1"){
var vTotal2 = this.getField(cTotal2).value;
}else{
var vTotal2 = "";
}
if(vStatus3 == "1"){
var vTotal3 = this.getField(cTotal3).value;
}else{
var vTotal3 = "";
}
if(vStatus4 == "1"){
var vTotal4 = this.getField(cTotal4).value;
}else{
var vTotal4 = "";
}
if(vStatus5 == "1"){
var vTotal5 = this.getField(cTotal5).value;
}else{
var vTotal5 = "";
}
if(vStatus6 == "1"){
var vTotal6 = this.getField(cTotal6).value;
}else{
var vTotal6 = "";
} 
// clear result value
event.value = "";
// add values
var FLPTotal = vTotal1 + vTotal2 + vTotal3 + vTotal4 + vTotal5 + vTotal6;
event.value = FLPTotal;

如何让此脚本在发生更改时重新计算? 这也在PDF文件中。

编辑:进一步的测试表明运行顺序似乎是问题所在。 vTotal1 将成功添加到 vTotal2,然后添加到 vTotal3,只要它们按该顺序填充。 vTotal1 不会与 vTotal3 相加。 如何按任意顺序对字段求和?

首先,我不确定为什么为每个字段创建多个变量。 这样的事情会起作用吗?

var FLPTotal = 0;

然后,如果满足其中一个条件,您只需向其添加值即可。

FLPTotal += this.getField(cTotal3).value;

如果它作为字符串返回,您可以这样做。

FLPTotal += parseInt(this.getField(cTotal3).value);

下面将汇总 cTotals 的所有值。

// field names
var cTotal1 = "Day1Pd1Total";
var cTotal2 = "Day1Pd2Total";
var cTotal3 = "Day1Pd3Total";
var cTotal4 = "Day1Pd4Total";
var cTotal5 = "Day1Pd5Total";
var cTotal6 = "Day1Pd6Total";
var cStatus1 = "Day1Pd1Status";
var cStatus2 = "Day1Pd2Status";
var cStatus3 = "Day1Pd3Status";
var cStatus4 = "Day1Pd4Status";
var cStatus5 = "Day1Pd5Status";
var cStatus6 = "Day1Pd6Status";
// get conditional field values
var vStatus1 = this.getField(cStatus1).value;
var vStatus2 = this.getField(cStatus2).value;
var vStatus3 = this.getField(cStatus3).value;
var vStatus4 = this.getField(cStatus4).value;
var vStatus5 = this.getField(cStatus5).value;
var vStatus6 = this.getField(cStatus6).value;
// Add total variable
var FLPTotal = 0;
// get field values base on condition
if(vStatus1 == "1"){
FLPTotal += parseInt(this.getField(cTotal1).value);
}
if(vStatus2 == "1"){
FLPTotal += parseInt(this.getField(cTotal2).value);
}
if(vStatus3 == "1"){
FLPTotal += parseInt(this.getField(cTotal3).value);
}
if(vStatus4 == "1"){
FLPTotal += parseInt(this.getField(cTotal4).value);
}
if(vStatus5 == "1"){
FLPTotal += parseInt(this.getField(cTotal5).value);
}
if(vStatus6 == "1"){
FLPTotal += parseInt(this.getField(cTotal6).value);
}
// clear result value and set result value
event.value = "";
event.value = FLPTotal;

告诉我这是否有效。

不确定我是否正确理解它,但如果您希望它简洁,并假设所有字段的值都是安全的(例如没有未定义(,那么您可以使用

Object.values(some object)

使字段的值成为数组。然后它将是两个数组的内部乘积:一个来自"vStatus"部分的切片,另一个来自"cTotal"部分。

Math.js 可能是一个有效的外部库,可以简洁地解析内部积。

Object.values 的例子在这里 (MDN(

const object1 = {
a: 'somestring',
b: 42,
c: false
};
console.log(Object.values(object1));
// expected output: Array ["somestring", 42, false]

尝试创建输入并将其声明为js文件中的对象,并尝试在if 语句大小写中使用此对象以包含结果。然后在if 语句全局之外使用它,并告诉我它是否有效。

let  vTotal1_val=document.querySelector("#inpt-first-val")
let  vTotal2_val=document.querySelector("#inpt-second-val")
if(case1 === true){
let vTotal1 = this.getField(cTotal4).value;
vTotal1_val.value=vTotal1
}
if(case2 === true){
let vTotal2 = this.getField(cTotal4).value;
vTotal2_val.value=vTotal2
}
let result =Number(vTotal1_val.value)+Number(vTotal2_val.value)
console.l(result)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input type="text" id="inpt-first-val" hidden>
<input type="text" id="inpt-second-val" hidden>

</body>
</html>

最新更新