1

我已经编写了一个复合组件,并且想使用保留的 EL#{component.clientId}来进行 JQuery 绑定。为了在页面的另一个地方(组件之外)使用这个检索到的 clientId,我使用 JSTL 将它存储在视图范围变量中。奇怪的是,JSTL 似乎阻止了将其 id 附加到其子项(NamingContainer行为)前面的自然复合组件行为。我知道 JSTL 有点棘手,ui:repeat因为生命周期的事情会干扰其他组件(例如),但在这里我不理解这种行为。

一些具体的代码比这个长篇演讲更好:

<html xmlns="http://www.w3.org/1999/xhtml"
        xmlns:ui="http://java.sun.com/jsf/facelets"
        xmlns:f="http://java.sun.com/jsf/core"
        xmlns:h="http://java.sun.com/jsf/html"
        xmlns:rich="http://richfaces.org/rich"
        xmlns:c="http://java.sun.com/jsp/jstl/core"    
        xmlns:composite="http://java.sun.com/jsf/composite">
    <composite:interface>
        […]
    </composite:interface>
    <composite:implementation>
        <rich:dataTable id="mySoLovedDataTable" […]>
            #{component.clientId}
            <!-- Commenting or uncommenting this line make the whole point -->
            <c:set var="targetClientId" value="#{component.clientId}" scope="view" />
            […]
        </rich:dataTable>
    </composite:implementation>
</html>

加上注释的行,#{component.clientId}给出类似j_idt261:mySoLovedDataTable.

注释掉该行后,它只给出mySoLovedDataTable.

4

1 回答 1

3

JSTL 在视图构建期间运行。它在 JSF 将视图模板解析为一个完整且可呈现的 JSF 组件树时运行。JSF 在视图渲染期间运行。它在 JSF 将组件树编码为一堆 HTML 时运行。您可以将其可视化如下:JSTL 首先从上到下运行,并仅生成带有 JSF 标记的结果。然后,在 JSF 渲染响应阶段,JSF 将从上到下运行并产生 HTML 结果。

换句话说,JSTL 和 JSF 并不像您对编码所期望的那样同步运行。通常您想使用 Facelets'<ui:param>而不是 JSTL <c:set>

<ui:param name="targetClientId" value="#{component.clientId}" />

请注意,这并没有真正在任何范围内设置任何内容。它只是为给定的表达式创建一种“别名”。我不确定它是否按照您的意图在您的特定情况下工作,但据我了解功能要求,您希望能够在组件之后<rich:dataTable>在视图中进一步获取客户端 ID。在这种情况下,最好使用:binding

<rich:dataTable binding="#{table}" ...>
    ...
</rich:dataTable>

<script>
    var $table = jQuery("[id='#{table.clientId}']");
    // ...
</script>
于 2011-08-23T12:07:47.617 回答