EBS Form个性化的工作原理

      之前一直没怎么研究它的工作原理,都是直接用。最近有个同事问我问题,说他在个性化编写的代码无效果。解决之后,才发现,原来传说中的EBSForm的个性化是这样子实现的。

了解工作原理之后,我可以编写一些实用的个性化作为补充了(要修改包APP_STANDARD.EVENT)。因为现在个性化可用的触发器实在是太少了。以后再说。

说正题。

简而言之,Form个性化的工作原理是触发器代码的“添加”。那添加在哪里呢?什么时候会被执行?是这样子的,我们在个性化编写的条件(包括触发器名称,条件等等),系统先会自动将对应的代码“添加”在APP_STANDARD.EVENT对应的触发器代码里面(其实是APP_STANDARD.EVENT会寻找个性化里面的代码去执行),然后Form级触发器调用代码的时候,会自动执行对应的触发器的增加在个性化里面的代码,从而达到个性化实现效果的目的。

举个简单的例子。我在个性化WHEN-VALIDATE-RECORD编写了一堆条件。

在Form打开的时候,做对应的操作之后,就会触发Form级的WHEN-VALIDATE-RECORD触发器(如果块级没有Override的同样的触发器的话),接着会执行里面的APP_STANDARD.EVENT ('WHEN-VALIDATE-RECORD');代码。

然后,由于APP_STANDARD.EVENT ('WHEN-VALIDATE-RECORD')代码“包括”了我增加在个性化里面写的条件和执行的内容等等,所以,个性化就被执行,可以有效果出来。

所以,当你在个性化里面添加了触发器和对应的执行条件,如果都不会被执行,而且你确认你的条件是满足的前提下,你可以打开对应的Form,确认Form级触发器有没有对应的触发器名称,还有,里面的是否有代码:APP_STANDARD.EVENT(对应的触发器名称)。

如果没有,赶忙增加,然后。。。

----

啰嗦一点,了解上面的原理之后,相信大家都想到一点:触发器的执行层次可能也会影响到个性化的触发!

为什么?

因为,我们一般在Form的Block里面添加的触发器,其执行层次一般是:Override。

这样子会导致一个后果:你在对应的块,再用个性化编写对应的触发器代码(上面的例子就是WHEN-NEW-RECORD-INSTANCE),那这个个性化的代码永远不会被执行。为什么?因为块级的WHEN-NEW-RECORD-INSTANCE触发器的执行层次已经覆盖了Form级的执行层次!而个性化的代码是添加在Form级的触发器的。

所以,在客制开发Form的时候就要注意这点了。如果你还想用对应触发器的个性化添加代码的话,最好将执行层次改为:Before。

 

 

备注:如果对Form的触发器执行层级不了解的话,可以看看下面的例子。

同样的触发器,在Item级,Block级,Form级都建一个。

对应的触发器的属性设定不一样的时候,测试的结果:

Item:Before/Block: Before /Form: Before

执行效果: Item-->Block-->Form

设为Before,执行顺序正常,从小到大。

 

Item:After/Block:Override/Form:Override

执行效果:Block-->Item-->Form级不执行

设为Override,则就是对应层次的触发器的断点。上一级的不会被执行。

 

Item:After/Block:Override/Form:After

执行效果:Block-->Item-->Form级不执行

 

Item:After/Block:Override/Form: Before

执行效果:Block-->Item-->Form级不执行

 

Item:After/Block: After/Form:After

执行效果:Form-->Block-->Item

设为After的话,执行的顺序会颠倒。

 

Item:After/Block: After/Form:Override

执行效果:Form-->Block-->Item

设为After的话,执行的顺序会颠倒。

 

Item:After/Block: Before/Form:Override

执行效果:Block -->Form-->Item

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值