将javascript代码传递给Custom Control

Nav*_*een 1 xpages

我需要将javascript代码(服务器端和客户端)传递给自定义控件,然后应该在自定义控件内的单击按钮上执行.

为此,我在自定义控件中创建了一个属性,例如codessjs,使用类型javax.faces.el.MethodBinding和编辑器作为方法绑定编辑器.在单击按钮(在自定义控件内)我写了这样的代码:

compositeData.codessjs.invoke(facesContext, null)

但是,'compositeData.codessjs' is null尽管代码存在于XPage源代码中,但它仍然会引发错误.如何让代码执行?

对于客户端javascript代码,我可以Client side script editor在自定义控件属性中找到编辑器,但属性的类型应该是什么?如何在自定义控件中执行csjs代码?

Sve*_*ach 5

如果要以这种方式使用方法绑定,则必须创建方法绑定作为自定义控件的参数:

<xc:ccMethod>
   <xc:this.codessjs>
      <![CDATA[#{javascript:
         var app = facesContext.getApplication();
         app.createMethodBinding("#{javascript:print('HELLO!');}", null);
       }]]>
   </xc:this.codessjs>
</xc:ccMethod>
Run Code Online (Sandbox Code Playgroud)

然后,您在自定义控件内的按钮可以调用该方法.在这种情况下,按钮将打印你好!到服务器控制台.

编辑:
CSJS属性的类型是字符串.要执行CSJS代码,您可以将自定义控件中的按钮修改为以下内容:

<xp:button value="Label" id="button1">
   <xp:eventHandler event="onclick" submit="false">
      <xp:this.script><![CDATA[#{javascript:compositeData.codecsjs}]]></xp:this.script>
   </xp:eventHandler>
</xp:button>
Run Code Online (Sandbox Code Playgroud)

在XPage中,可以通过以下方式填充自定义控件属性:

<xc:ccCSJS>
   <xc:this.codecsjs>
      <![CDATA[alert("ABC");]]>
   </xc:this.codecsjs>
</xc:ccCSJS>
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助

斯文