更改为服务器端处理后,row-attribute不再工作

时间:2017-06-21 08:03:31

标签: json datatables dandelion

我将数据表更改为服务器端处理。从这一点开始,行属性似乎不再起作用了。

这是我对JSP中数据表的定义:

<datatables:table id="users" url="/user_User_Json_List_Dandelion.action" serverSide="true" row="user">
        <datatables:column titleKey="user.user.list.username" sortable="false" property="benutzername" />
        <datatables:column titleKey="user.user.list.prename" sortable="false" property="person.vorname" />
        <datatables:column titleKey="user.user.list.surname" sortable="false" property="person.nachname" />
        <datatables:column titleKey="user.user.list.email" sortable="false" property="person.email" />
        <datatables:column cssCellClass="img" sortable="false" cssCellStyle="width: 40px">
            bla<c:if test="${user.gesperrt}">
                <img src="<%=request.getContextPath()%>/static/images/locked.gif" title="<s:text name="%{getText('user.user.list.locked')}"/>"
                    alt="<s:text name="%{getText('user.user.list.locked')}"/>" />
            </c:if>
            <c:if test="${!user.aktiv}">
                <img src="<%=request.getContextPath()%>/static/images/delete.gif" title="<s:text name="%{getText('user.user.list.delete')}"/>"
                    alt="<s:text name="%{getText('user.user.list.delete')}"/>" />
            </c:if>
        </datatables:column>
        <datatables:column cssCellClass="img" sortable="false" cssCellStyle="width: 20px">
            <c:if test="${!user.systemBenutzer}">
                <s:url var="edit" action="user_User_Edit_Pre">
                    <s:param name="benutzerId">${user.benutzerId}</s:param>
                </s:url>
                <s:a href="%{edit}" title="%{getText('user.user.edit.header')}">
                    <img src="<%=request.getContextPath()%>/static/images/edit.gif" title="<s:text name="%{getText('user.user.edit.header')}"/>"
                        alt="<s:text name="%{getText('user.user.edit.header')}"/>" />
                </s:a>
            </c:if>
        </datatables:column>
        <datatables:column cssCellClass="img" sortable="false" cssCellStyle="width: 20px">
            <s:url var="listRights" action="user_Auth_List_Pre">
                <s:param name="benutzerId">${user.benutzerId}</s:param>                   
            </s:url>
            <s:a href="%{listRights}" title="%{getText('user.user.list.listRights')}">
                <img src="<%=request.getContextPath()%>/static/images/user_details.gif" title="<s:text name="%{getText('user.user.list.listRights')}"/>"
                    alt="<s:text name="%{getText('user.user.list.listRights')}"/>" />
            </s:a>
        </datatables:column>
    </datatables:table>

所有电话,例如''不工作,因为我开启了服务器端处理,所以没有用户变量。

来自Json WebService的我的Json结果看起来像:

{"data":[{"aktiv":true,"benutzerId":"8a2fde263d8b94000144020a7e066fa5","benutzername":"adm_boegel","gesperrt":false,"systemBenutzer":false},{.....

所以这里出了什么问题? 我还能如何访问数据?

感谢您的帮助。

编辑:

仅用于测试我将其中一个列更改为:

<datatables:column cssCellClass="img" sortable="false" cssCellStyle="width: 40px">
                hello
        </datatables:column>

'你好'永远不会在大约2500行中打印出来。

EDIT2:

每当设置到服务器端我只能通过访问数据     

当不使用服务器端时我也可以使用行属性等     $ {user.gesperrt}

也许这是一个错误?

1 个答案:

答案 0 :(得分:0)

如doc

中的前一章所述

8.3。自定义列内容

只能使用property-property来使用列标记,并且我使用renderFunction-property来调用java脚本,然后可以处理某些逻辑。 但在我的观察中,这些java脚本调用返回一些html(如img-tag)会降低渲染速度。

我希望在最终服务器端处理虽然会在速度方面带来一些好处。

我的蒲公英数据表列如下:

        <datatables:column property="aktiv" renderFunction="produceUserLockedIcon"/>

我的java脚本如下:

<script type="text/javascript">
    function produceUserLockedIcon(data, type, full) {

        return "testString: " + '<a href="blaa">blaa</a>' + '<img src="<%=request.getContextPath()%>/static/images/locked.gif"\>';
    }
</script>