增强公式编辑器,能让公式支持脚本和实时计算。
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.
richie af8fcf04fc 改为gradle打包 3 days ago
lib 去掉不规范的依赖 10 months ago
screenshots 示例问题 2 years ago
shop 说明 2 years ago
src/main 搜索方法修改 3 weeks ago
.gitignore 变更示例 1 year ago
build.gradle 改为gradle打包 3 days ago
build.xml KERNEL-1117 完成了插件部分SDK实现 11 months ago
encrypt.xml 改为gradle打包 3 days ago
plugin.xml 改为gradle打包 3 days ago
pom.xml 去掉不规范的依赖 10 months ago
readme.md 222 7 months ago

readme.md

增强公式编辑器插件

该插件提供两个功能:公式支持JavaScript脚本、公式支持实时查看计算结果。

公式编辑器视图

插件提供的公式编辑器图示如下:

formula

可以在看到增加的两部分都使用红字标了出来。

具体使用

1、新建一个模板,在A1中设置一个值为12;

2、在B1中增加一个常规公式,内容为

"A1的值" + if (A1 > 10, "大于10","小于等于10")

3、在B2中增加一个脚本公式,内容为

var a1 = '${A1}';
return "A1的值" + (a1 > 10 ? "大于10" : "小于等于10");

模板的设置如下图所示:

tpl

预览该模板,可以看到结果是一样的:

preview

实时计算

在脚本公式中,写入下面的脚本内容:

var a1 = number('${A1}');
var a2 = number('${A2}');
return "A1 + A2的值" + (a1 + a2 > 10 ? "大于10" : "小于等于10");

点击实时计算按钮,会弹出来要求输入A1和A2的值,输入后,就可以看到正确的计算结果了:

input

结果为如下图所示:

result

注意事项

1、常规公式和脚本公式都支持实时计算。

2、脚本公式中内置了三个函数:array、int、number,可以分别将其参数转换为数组、整数以及数字,比如:

var a1 = array('${A1}'); // 将A1格子的值转换为数组,参与JS运算
var a2 = int('${A2}'); // 将A2格子的值转换为整数,参数JS运算
var a3 = number('${A3}'); // 将A3格子的值转换为浮点数,参数JS运算

3、如果明确格子或者参数是数字,可以写成(这种写法一般不推荐)

var a = ${A1};

这种写法,a作为数字参与后续的运算;

如果有可能是其他类型,需要写为

var a = '${A1}';

这种写法,a作为字符串参与后续的运算;

3、脚本公式在返回数组类型的时候,和常规公式的ARRAY表现一致。

4、脚本公式在返回对象的时候,实际只把对象value作为数组返回。