1

我正在尝试在数据表行中显示从服务器接收到的 html 文本。

表格如下所示:

<h:form id="carPageForm" prependId="false">

                <p:dataTable var="car" value="#{tableBean.lazyModel}" paginator="true"
                    rows="10" rowKey="#{car.id}" widgetVar="carsTable"
                    paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
                    selectionMode="single"
                    selection="#{tableBean.selectedCar}" id="carTable">

                    <f:facet name="header">
                        <p:outputPanel>
                            <p:inputText id="globalFilter" onkeyup="carsTable.filter()" style="float:right"/>
                            <h:outputText value="Search all fields:" style="float: right; margin-top: 2px;" />
                        </p:outputPanel>
                    </f:facet>

                    <p:ajax event="rowSelect" update=":carPageForm:display"
                        oncomplete="carDialog.show()" />

                    <p:column id="idColumn" filterBy="#{car.id}" style="display:none"
                        filterMatchMode="contains">
                        <h:outputText value="#{car.id}" />
                    </p:column>

                    <p:column id="adColumn" filterBy="#{car.ad}" filterStyle="display:none">
                        <h:outputText value="#{car.ad}" escape="true"/>
                    </p:column>
                </p:dataTable>

                <p:dialog header="Car Detail" widgetVar="carDialog"
                    resizable="false" showEffect="scale" hideEffect="explode">

                    <h:panelGrid id="display" columns="2" cellpadding="4">

                        <h:outputText value="Title:" />
                        <h:outputText value="#{tableBean.title}" style="font-weight:bold" />

                        <h:outputText value="Description:" />
                        <h:outputText value="#{tableBean.description}"
                            style="font-weight:bold" />

                        <h:outputText value="Price:" />
                        <h:outputText value="#{tableBean.price}" style="font-weight:bold" />
                    </h:panelGrid>
                </p:dialog>

            </h:form>


现在,如果我单击行上escape="true" 在此处输入图像描述
的任意位置,将触发 rowSelect 事件并打开对话框。
但是,如果我设置escape="false"为使行中的文本像这样既粗体又加下划线: 在此处输入图像描述
那么只有当我在文本之后单击空白区域时才会触发 rowSelect 事件。如果我单击文本上的任何位置,则不会发生任何事情。
即使我只是在<h:outputText>ie之前添加粗体标记
<b><h:outputText value="#{car.ad}"/></b>,即使这样,只有当我单击行中的任意位置时才会调用 select 事件,而是在文本上。
有人可以告诉我如何处理吗?

4

2 回答 2

3

这是因为当您选择不转义 outpuText 的值时,它实际上会在对应的 div 标记中呈现 html 元素。当您单击文本本身时,您实际上是在单击粗体和下划线 HTML 元素,并且 jQuery click 事件未注册到表格行。

此单击事件绑定到类的元素,ui-dt-c因此如果您使用具有此类的 div 将文本包装在 html 元素中,则单击文本将触发单击事件。

<b><u><div class="ui-dt-c"> e78fe894 Ferrari Blue 1994 </div></u></b>
于 2012-05-24T11:52:05.323 回答
1

这种情况对我来说也很神奇,但不幸的是,建议的解决方案对我不起作用。最后,我找到了非常简单但有效的解决方案。

instead of using <b> tag I have used <span> tag like this:

<span style="font-weight:bold">hello</span>

即使我单击列中的“你好”字样,行选择也会再次起作用。

于 2014-10-17T21:51:09.623 回答