问题
I have a JSF page with a rich:dataTable
where, in each row, I put h:commandLink
s to lead to pages with the details of the row selected.
I wanted to make the whole row clickable, calling the action method when the user clicks anywhere in the row.
Is that possible without JavaScript? And if JavaScript is the only way out, what would be the best way do it? Search for a commandLink and "click" it?
Thanks in advance!
回答1:
I got the whole rows clickable with a bit of styling. I made the links inside the cells occupy the whole cell with display: block;
for the links and padding:0
for the cell.
So, here is what you need to do. In the JSF page, set up rowClasses
and the links in each cell:
<rich:dataTable value="#{myMB.listaElems}" var="elem" rowClasses="clickable">
<rich:column>
<h:commandLink action="#{myMB.preUpdate(elem)}" value="#{elem.item1}" />
</rich:column>
<rich:column>
<h:commandLink action="#{myMB.preUpdate(elem)}" value="#{elem.item2}" />
</rich:column>
</rich:datatable>
And in the CSS sheet:
tr.clickable td {
padding: 0;
}
tr.clickable td a {
display: block;
padding: 4px;
}
And that's it!
The only downside is that you need to repeat the link in each cell, but the HTTP flow remains simple, you don't need to change any component, and it will work for h:link
s or good old <a>
html links -- a pretty acceptable tradeoff, I'd say. :)
回答2:
The basic problem is that JSF (core) is tied to the HTML table
element for query-result rendering via the dataTable
component. Since a JSF dataTable
renders as an HTML table
, the result is limited to what can be managed in columns (no out-of-the-box row control that I have seen). The HTML/CSS way to do this is quite elegant but in order to accomplish this in JSF, I believe the UIComponent
renderer for dataTable
would need to be overridden to output this:
<div class="table">
<a href="#" class="row">
<span class="cell">Column-1-Value</span>
<span class="cell">Column-2-Value</span>
</a>
...
</div>
With CSS styles table
row
and cell
representing display:table
, display:table-row
and display:table-cell
; respectively. This makes the row completely clickable but it behaves as a proper table. I have not embarked on re-writing the JSF renderers and solving the JSF commandLink
and other component problems to accomplish the rendering as above but that is probably the ultimate answer. I am not a fan of JSF after fighting with it on a few projects now (as compared to lighter weight combinations of concepts from basic HTML/CSS, a sprinkling of JavaScript, clean Java/Servlets, etc).
回答3:
in your datatable use this one:
<a4j:jsFunction name="selectRow" action="#{userBean.myListener" ...>
<a4j:param name="currentRow" assignTo="#{userBean.selectedRowId}"/>
</a4j:jsFunction>
its called when you select a row, and you can do whatever you want and pass the selected row with the <a4j:param
...as an option you should also be able to call yourLink.click()
or something similar, but that wont be the problem to find out...
reference : Richfaces Forum
回答4:
You may want to try rich:scrollableDataTable
. it has attribute onRowClick
which you can specify as an event
attribute into a4j:support / a4j:ajax
nested inside your table. This will make your row clickable.
-cheers :)
回答5:
For the new RichFaces 4.x, you can use the a4j:commandLink
this instead, and make the complete row selectable in CSS. Notice that the 'rowClasses="clickable"
' refers to the CSS class to select the whole row:
<rich:column id="fileName" sortable="false" width="618px">
<a4j:commandLink action="#{controller.setSelectedFile(file)}"
oncomplete="window.open('#{menuBar.PrintPage}?outputType=pdf', '_blank');"
rendered="#{not controller.getButtonDisabled(file)}"
execute="@this" limitRender="true">
<h:outputText value="${file}"
style="text-align:left;width:100%;min-width:400px;"
title="${file.name} is viewable.">
<f:converter converterId="MVC.View.Converter_FilePath" />
</h:outputText>
</a4j:commandLink>
</rich:column>
Use this CSS class to select the whole row:
tr.clickable td {
padding: 0;
}
tr.clickable td a {
display: block;
padding: 4px;
}
来源:https://stackoverflow.com/questions/8422122/how-to-make-a-clickable-row-in-a-richdatatable