0

我在数据表中收到了这个“Base is null: item”jsf1.1 错误,我只是不太明白。这是一个二级数​​据表,错误发生在二级数据表上。第一级数据表绑定到 ArrayList deviceListDeviceReferences 的值。在此数据表中,它有一列包含另一个数据表。这个 2 级数据表绑定到 ArrayList holderNameMasks 的值。它从 DeviceReferenceJTO 检索到的这个值,它基本上是第一个数据表中的行项。

以下是html的片段:

<h:dataTable border="0" cellspacing="0"
    value="#{deviceReferenceBean.deviceListDeviceReferences" var="item"  
    rendered="#{not empty deviceReferenceBean.deviceListDeviceReferences }"  
    binding="#{deviceReferenceBean.deviceListDeviceReferencesTable}"
>
    <h:column>
        <h:outputText value="Holder Name:" />
        <!--  device heading -->
        <h:outputText value="#{item.deviceLabel }" styleClass="DeviceReferenceTitleBarBorder" style="width:100%; height:30px; background-color:#f9f9f9"/>
        <!-- holder name -->   
        <h:panelGrid columns="2" rendered="#{item.hasHolderNameMasks}" >
            <h:outputText value="Holder Name:" />
            <h:dataTable border="0" cellspacing="0" 
                value="#{item.holderNameMasks}" var="holderMaskItem"  
                rendered="#{not empty deviceReferenceBean.deviceListDeviceReferences and item.hasHolderNameMasks}"  
                binding="#{item.holderNameMasksTable}"
            >
                <h:column>
                    <h:outputText value="#{holderMaskItem.fieldLabel}" />
                </h:column>
                <h:column>
                    <h:panelGrid columns="1">
                        <h:inputText value="#{holderMaskItem.fieldValue}" />
                        <h:outputText value="#{holderMaskItem.instruction }" rendered="#{holderMaskItem.hasInstruction"/>
                    </h:panelGrid>
                </h:column>
            </h:dataTable>
        </h:panelGrid>  
    </h:column>
</h:dataTable>

下面是组件的样子:

<HtmlForm enctype="application/x-www-form-urlencoded" id="_idJsp323" rendered="true" styleClass="MAForm" submitted="false" transient="false">

    <HtmlDataTable border="0" cellspacing="0" first="0" id="_idJsp324" rendered="#{not empty deviceReferenceBean.deviceListDeviceReferences }=true" rowIndex="-1" rows="0" transient="false" var="item" binding="#{deviceReferenceBean.deviceListDeviceReferencesTable}">

        <UIColumn id="_idJsp325" rendered="true" transient="false">

            <HtmlOutputText escape="true" id="_idJsp326" rendered="true" style="width:100%; height:30px; background-color:#f9f9f9" styleClass="DeviceReferenceTitleBarBorder" transient="false"/>

            <HtmlPanelGrid border="-2147483648" columns="2" id="_idJsp327" rendered="#{item.hasHolderNameMasks}=true" transient="false">

                <HtmlOutputText escape="true" id="_idJsp328" rendered="true" transient="false" value="Holder Name:"/>

            </HtmlPanelGrid>

        </UIColumn>

    </HtmlDataTable>

</HtmlForm>
4

1 回答 1

1

罪魁祸首在这里:

<h:dataTable
    binding="#{item.holderNameMasksTable}"
>

UI 组件的binding(and id) 属性在视图构建期间(JSF 将 XHTML 文件解析为组件树的那一刻)解析。但是,#{item}它仅在视图呈现期间可用(JSF 将组件树编码为 HTML 输出的那一刻)。因此,您使用的地方binding="#{item.xxx}"总是会失败,因为#{item}is null。请注意,这正是异常试图告诉您的内容。

你有 2 个选择:

  1. 完全摆脱binding属性。
  2. 改为绑定#{deviceReferenceBean}。它在视图构建期间可用。

也可以看看:

于 2013-05-20T12:32:44.013 回答