Xpages自定义控件:将compositeData值放入SSJS函数中

Xpages自定义控件:将compositeData值放入SSJS函数中,xpages,Xpages,我发布了我用来解决这个问题的代码。感谢佩尔、埃里克·麦考密克和保罗·威瑟斯 <xp:scriptBlock id="scriptBlock2"> <xp:this.value><![CDATA[$(document).ready( function() { x$("#{javascript:return getComponent(compositeData.fieldName).getClientId(facesContext);}").selec

我发布了我用来解决这个问题的代码。感谢佩尔、埃里克·麦考密克和保罗·威瑟斯

<xp:scriptBlock id="scriptBlock2">
        <xp:this.value><![CDATA[$(document).ready(
function() { 
x$("#{javascript:return getComponent(compositeData.fieldName).getClientId(facesContext);}").select2({
                                placeholder : "Choose an employee",
                                allowClear: true,
                                minimumResultsForSearch : 3
                            })  
}
);                      
]]>
        </xp:this.value>
    </xp:scriptBlock>
在CC的其他部分,我使用该计算来访问id号,例如:

    <xp:message 
            id="message1"
            for="#{javascript:compositeData.fieldName}"
            styleClass="help-block">
        </xp:message>

但是,在构建Select2 CC时,我需要在脚本中添加一些SSJ,如下所示:

<xp:scriptBlock id="scriptBlock2">
        <xp:this.value><![CDATA[
            $(document).ready(
                function() {
                x$("#{id:[compositeData.fieldName]}").select2({
                placeholder: "Select An Employee",
                allowClear: true
                });
                }
                );
]]></xp:this.value>
    </xp:scriptBlock>

但这不起作用。我不知道如何动态生成ID

x$("#{id:[compositeData.fieldName]}")


<?xml version="1.0" encoding="UTF-8"?>
<xp:view
    xmlns:xp="http://www.ibm.com/xsp/core"
    id="view1">



    <xp:scriptBlock id="scriptBlock2">
        <xp:this.value><![CDATA[
            $(document).ready(
                function() {
                x$("#{id:[compositeData.fieldName]}").select2({
                placeholder: "Select An Employee",
                allowClear: true
                });
                }
                );
]]></xp:this.value>
    </xp:scriptBlock>


    <xp:div>
    <xp:this.styleClass><![CDATA[#{javascript:"form-group" + (getComponent(compositeData.fieldName).isValid() ? "" : " has-error")}]]></xp:this.styleClass>
            <xp:label
            styleClass="control-label"
            for="#{javascript:compositeData.fieldLabel}"
            value="${compositeData.fieldLabel}" />
            <div class="">

            <xp:comboBox 
                id="${javascript:compositeData.fieldName}"
                value="#{compositeData.dataSource[compositeData.fieldName]}"
                required="${compositeData.required}">
                <xp:selectItems
                        value="${javascript:'#{CacheBean.'+compositeData.cacheItem+'}'}">
                    </xp:selectItems>
                <xp:this.validators>
                    <xp:validateRequired message="#{javascript:compositeData.fieldLabel + ' is required'}"></xp:validateRequired>
                </xp:this.validators>
            </xp:comboBox>

            <xp:scriptBlock
                id="scriptBlock1">
            <xp:this.value>
            <![CDATA[x$("#{id:comboBox5}").select2({minimumResultsForSearch:5});]]>
            </xp:this.value>
            </xp:scriptBlock>

            <xp:text
                    escape="true"
                    id="computedField1"
                    styleClass="help-block"
                    value="${compositeData.helpText}">
                    <xp:this.rendered><![CDATA[#{javascript:(getComponent(compositeData.fieldName).isValid()) && compositeData.helpText != null}]]></xp:this.rendered>
            </xp:text>

            <xp:message 
                id="message1"
                for="#{javascript:compositeData.fieldName}"
                styleClass="help-block">
            </xp:message>
        </div>

    </xp:div>


    <xp:text escape="true" id="computedField2"      
        value="${javascript:'#{id.'+compositeData.fieldName+'}'}">
    </xp:text>


</xp:view>
x$(“#{id:[compositeData.fieldName]}”)

您可以使用SSJS函数
getClientId()
从客户端JS(使用SSJS)获取动态生成的id。因此,在您的情况下,它将与x$函数组合如下:

x$('#{javascript:getClientId(compositeData.fieldName)}')

您可以使用SSJS函数
getClientId()
从客户端JS(使用SSJS)获取动态生成的id。因此,在您的情况下,它将与x$函数组合如下:

x$('#{javascript:getClientId(compositeData.fieldName)}')

使用标准onClientLoad只调用x$(…调用)怎么样?使用标准onClientLoad只调用x怎么样$(…打电话?谢谢这个答案。通过一些调整有效!我更新了我的问题以发布我最终使用的代码。谢谢这个答案。通过一些调整有效!我更新了我的问题以发布我最终使用的代码。