增强公式编辑器,能让公式支持脚本和实时计算。
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

89 lines
2.1 KiB

6 years ago
# 增强公式编辑器插件
该插件提供两个功能:公式支持JavaScript脚本、公式支持实时查看计算结果。
## 公式编辑器视图
插件提供的公式编辑器图示如下:
![formula](screenshots/show.png)
可以在看到增加的两部分都使用红字标了出来。
## 具体使用
1、新建一个模板,在A1中设置一个值为12;
2、在B1中增加一个常规公式,内容为
```
"A1的值" + if (A1 > 10, "大于10","小于等于10")
```
3、在B2中增加一个脚本公式,内容为
```
var a1 = '${A1}';
return "A1的值" + (a1 > 10 ? "大于10" : "小于等于10");
```
模板的设置如下图所示:
![tpl](screenshots/tpl.png)
预览该模板,可以看到结果是一样的:
![preview](screenshots/preview.png)
## 实时计算
在脚本公式中,写入下面的脚本内容:
```
6 years ago
var a1 = number('${A1}');
var a2 = number('${A2}');
6 years ago
return "A1 + A2的值" + (a1 + a2 > 10 ? "大于10" : "小于等于10");
```
点击实时计算按钮,会弹出来要求输入A1和A2的值,输入后,就可以看到正确的计算结果了:
![input](screenshots/input.png)
结果为如下图所示:
![result](screenshots/result.png)
## 注意事项
1、常规公式和脚本公式都支持实时计算。
6 years ago
2、脚本公式中内置了三个函数:array、int、number,可以分别将其参数转换为数组、整数以及数字,比如:
```
var a1 = array('${A1}'); // 将A1格子的值转换为数组,参与JS运算
var a2 = int('${A2}'); // 将A2格子的值转换为整数,参数JS运算
var a3 = number('${A3}'); // 将A3格子的值转换为浮点数,参数JS运算
```
4 years ago
6 years ago
3、如果明确格子或者参数是数字,可以写成(这种写法一般不推荐)
```
var a = ${A1};
```
这种写法,a作为数字参与后续的运算;
4 years ago
如果有可能是其他类型,需要写为
```
var a = '${A1}';
```
4 years ago
这种写法,a作为字符串参与后续的运算;
3、脚本公式在返回数组类型的时候,和常规公式的ARRAY表现一致。
6 years ago
4、脚本公式在返回对象的时候,实际只把对象value作为数组返回。
6 years ago