公式类型,可以设置公式,并将结果设置给目标值。
type
请设置成formula
name
这是变量名,公式结果将作用到此处指定的变量中去。formula
公式。如:data.var_a + 2
,其实就是 JS 表达式。condition
作用条件。有两种写法- 用 tpl 语法,把关联的字段写上如:
${xxx} ${yyy}
意思是当 xxx 和 yyy 的取值结果变化了就再应用一次公式结果。 - 自己写判断如:
data.xxx == "a" && data.xxx !== data.__prev.xxx
当 xxx 变化了,且新的值是字符 "a" 时应用,可以写更加复杂的判断。
- 用 tpl 语法,把关联的字段写上如:
initSet
初始化时是否设置。默认是true
autoSet
观察公式结果,如果计算结果有变化,则自动应用到变量上。默认为true
。id
定义个名字,当某个按钮的目标指定为此值后,会触发一次公式应用。这个机制可以在autoSet
为 false 时用来手动触发。为什么不是设置
name
? 因为 name 值已经用来设置目标变量名了,这个表单项肯定已经存在了,所以不是唯一了,不能够被按钮指定。
[
{
"type": "number",
"name": "a",
"label": "A"
},
{
"type": "number",
"name": "b",
"label": "B"
},
{
"type": "number",
"name": "sum",
"label": "和",
"disabled": true,
"description": "自动计算 A + B"
},
{
"type": "formula",
"name": "sum",
"value": 0,
"formula": "a + b"
}
]
公式最常见的用法,就是用来实现,当某个值发生变化时,将另外一个值置空如:
[
{
"type": "radios",
"options": ["1", "2"],
"name": "a",
"label": "A",
"description": "当 A 发生变化时,原来选择的 B 可能已经失效,所以利用公式把 B 值清空。"
},
{
"type": "radios",
"name": "b",
"options": ["3", "4"],
"label": "B",
"visibleOn": "this.a != 2"
},
{
"type": "radios",
"name": "b",
"options": ["5", "6"],
"label": "B",
"visibleOn": "this.a == 2"
},
{
"type": "formula",
"name": "b",
"condition": "${a}",
"formula": "''"
}
]