我将数据表更改为服务器端处理。从这一点开始,行属性似乎不再起作用了。
这是我对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行中打印出来。
每当设置到服务器端我只能通过访问数据
当不使用服务器端时我也可以使用行属性等 $ {user.gesperrt}
也许这是一个错误?
答案 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>