How to use apex:dataTable in Visualforce Page?
<apex:dataTable>:
An HTML table that is defined by iterating over a set of data, displaying information about one item of data per row. The body of the < apex:dataTable > contains one or more column components that specify what information should be displayed for each item of data. The data set can include up to 1,000 items.
This tag supports following attributes:
In this post i am giving an example of <apex:dataTable> applying custom styles.
Controller Class:
public class TableController{
public List<Account> accList{get;set;}
public TableController(){
accList= new List<Account>();
accList= [select id,name,type,industry from Account];
}
}
Static Resources :
i upload an image from http://free-121d5f44d20-121d603d1c5-121ee2b8103.force.com/force2b/salesforceicons to static resources in salesforce.

Visualforce Page :
<apex:page controller="TableController" sidebar="false" wizard="true">
<style type="text/css">
.outBorder {
border:3px outset black;
}
.inBorder{
border-top:2px dotted blue;
border-left:2px dotted blue;
}
</style>
<apex:form >
<apex:pageBlock title="Data Table">
<apex:dataTable value="{!accList}" var="a" styleclass="outBorder" width="550px">
    
<apex:column styleclass="inBorder">
<apex:facet name="header">Image </apex:facet>
<apex:image value="{!$Resource.customerImage}"/>
</apex:column>
      
      
<apex:column styleclass="inBorder">
<apex:facet name="header">Account Name </apex:facet>
<apex:outputText >{!a.Name}</apex:outputText>
</apex:column>
      
<apex:column styleclass="inBorder">
<apex:facet name="header">Account type </apex:facet>
<apex:outputText >{!a.type}</apex:outputText>
</apex:column>
      
<apex:column styleclass="inBorder">
<apex:facet name="header">Account Industry </apex:facet>
<apex:outputText >{!a.industry}</apex:outputText>
</apex:column>
    
</apex:dataTable>
</apex:pageBlock>
</apex:form>
</apex:page>
Test Class:
@isTest
Public class DataTableWithStyles_Test {
static testmethod void testPageblockTable(){
//Test converage for the myPage visualforce page
PageReference pageref = Page.DataTableWithStyles;
Test.setCurrentPageReference(pageref);
  
// create an instance of the controller
TableController tc= new TableController();
}
}
Output:

An HTML table that is defined by iterating over a set of data, displaying information about one item of data per row. The body of the < apex:dataTable > contains one or more column components that specify what information should be displayed for each item of data. The data set can include up to 1,000 items.
This tag supports following attributes:
| 
Attribute | 
Description | 
| 
align | 
The position of the rendered HTML table with respect to the page. Possible values include "left", "center", or "right". If left unspecified, this value defaults to "left". | 
| 
bgcolor | 
The background color of the rendered HTML table. | 
| 
border | 
The width of the frame around the rendered HTML table, in pixels. | 
| 
captionClass | 
The style class used to display the caption for the rendered HTML table, if a caption facet is specified. This attribute is used primarily to designate which CSS styles are applied when using an external CSS stylesheet. | 
| 
captionStyle | 
The style used to display the caption for the rendered HTML table, if a caption facet is specified. This attribute is used primarily for adding inline CSS styles. | 
| 
cellpadding | 
The amount of space between the border of each table cell and its contents. If the value of this attribute is a pixel length, all four margins are this distance from the contents. If the value of the attribute is a percentage length, the top and bottom margins are equally separated from the content based on a percentage of the available vertical space, and the left and right margins are equally separated from the content based on a percentage of the available horizontal space. | 
| 
cellspacing | 
The amount of space between the border of each table cell and the border of the other cells surrounding it and/or the table's edge. This value must be specified in pixels or percentage. | 
| 
columnClasses | 
A comma-separated list of one or more classes associated with the table's columns, used primarily to designate which CSS styles are applied when using an external CSS stylesheet. If more than one class is specified, the classes are applied in a repeating fashion to all columns. For example, if you specify columnClasses="classA, classB", then the first column is styled with classA, the second column is styled with classB, the third column is styled with classA, the fourth column is styled with classB, and so on. | 
| 
columns | 
The number of columns in this table. | 
| 
columnsWidth | 
A comma-separated list of the widths applied to each table column. Values can be expressed as pixels (for example, columnsWidth="100px, 100px"). | 
| 
dir | 
The direction in which the generated HTML component should be read. Possible values include "RTL" (right to left) or "LTR" (left to right). | 
| 
first | 
The first element in the iteration visibly rendered in the table, where 0 is the index of the first element in the set of data specified by the value attribute. For example, if you did not want to display the first two elements in the set of records specified by the value attribute, set first="2". | 
| 
footerClass | 
The style class used to display the footer (bottom row) for the rendered HTML table, if a footer facet is specified. This attribute is used primarily to designate which CSS styles are applied when using an external CSS stylesheet. | 
| 
frame | 
The borders drawn for this table. Possible values include "none", "above", "below", "hsides", "vsides", "lhs", "rhs", "box", and "border". If not specified, this value defaults to "border". | 
| 
headerClass | 
The style class used to display the header for the rendered HTML table, if a header facet is specified. This attribute is used primarily to designate which CSS styles are applied when using an external CSS stylesheet. | 
| 
id | 
An identifier that allows the dataTable component to be referenced by other components in the page. | 
| 
lang | 
The base language for the generated HTML output, for example, "en" or "en-US". | 
| 
onclick | 
The JavaScript invoked if the onclick event occurs that is, if the user clicks the data table. | 
| 
ondblclick | 
The JavaScript invoked if the ondblclick event occurs that is, if the user clicks the data table twice. | 
| 
onkeydown | 
The JavaScript invoked if the onkeydown event occurs that is, if the user presses a keyboard key. | 
| 
onkeypress | 
The JavaScript invoked if the onkeypress event occurs that is, if the user presses or holds down a keyboard key. | 
| 
onkeyup | 
The JavaScript invoked if the onkeyup event occurs that is, if the user releases a keyboard key. | 
| 
onmousedown | 
The JavaScript invoked if the onmousedown event occurs that is, if the user clicks a mouse button. | 
| 
onmousemove | 
The JavaScript invoked if the onmousemove event occurs that is, if the user moves the mouse pointer. | 
| 
onmouseout | 
The JavaScript invoked if the onmouseout event occurs that is, if the user moves the mouse pointer away from the data table. | 
| 
onmouseover | 
The JavaScript invoked if the onmouseover event occurs that is, if the user moves the mouse pointer over the data table. | 
| 
onmouseup | 
The JavaScript invoked if the onmouseup event occurs that is, if the user releases the mouse button. | 
| 
onRowClick | 
The JavaScript invoked if the onRowClick event occurs that is, if the user clicks a row in the data table. | 
| 
onRowDblClick | 
The JavaScript invoked if the onRowDblClick event occurs that is, if the user clicks a row in the data table twice. | 
| 
onRowMouseDown | 
The JavaScript invoked if the onRowMouseDown event occurs that is, if the user clicks a mouse button in a row of the data table. | 
| 
onRowMouseMove | 
The JavaScript invoked if the onRowMouseMove event occurs that is, if the user moves the mouse pointer over a row of the data table. | 
| 
onRowMouseOut | 
The JavaScript invoked if the onRowMouseOut event occurs that is, if the user moves the mouse pointer away from a row in the data table. | 
| 
onRowMouseOver | 
The JavaScript invoked if the onRowMouseOver event occurs that is, if the user moves the mouse pointer over a row in the data table. | 
| 
onRowMouseUp | 
The JavaScript invoked if the onRowMouseUp event occurs that is, if the user releases the mouse button over a row in the data table. | 
| 
rendered | 
A Boolean value that specifies whether the component is rendered on the page. If not specified, this value defaults to true. | 
| 
rowClasses | 
A comma-separated list of one or more classes associated with the table's rows, used primarily to designate which CSS styles are applied when using an external CSS stylesheet. If more than one class is specified, the classes are applied in a repeating fashion to all rows. For example, if you specify columnRows="classA, classB", then the first row is styled with classA, the second row is styled with classB, the third row is styled with classA, the fourth row is styled with classB, and so on. | 
| 
rows | 
The number of rows in this table. | 
| 
rules | 
The borders drawn between cells in the table. Possible values include "none", "groups", "rows", "cols", and "all". If not specified, this value defaults to "none". | 
| 
style | 
The style used to display the dataTable component, used primarily for adding inline CSS styles. | 
| 
styleClass | 
The style class used to display the dataTable component, used primarily to designate which CSS styles are applied when using an external CSS stylesheet. | 
| 
summary | 
A summary of the table's purpose and structure for Section 508 compliance. | 
| 
title | 
The text to display as a tooltip when the user's mouse pointer hovers over this component. | 
| 
value | 
The collection of data displayed in the table. | 
| 
var | 
The name of the variable that represents one element in the collection of data specified by the value attribute. You can then use this variable to display the element itself in the body of the dataTable component tag. | 
| 
width | 
The width of the entire table, expressed either as a relative percentage to the total amount of available horizontal space (for example, width="80%"), or as the number of pixels (for example, width="800px"). | 
Visualforce Example:
<apex:page standardController="Lead" recordSetVar="Leads">
     <apex:pageBlock title="dataTable">
         <apex:dataTable value="{!Leads}" var="le" width="50%">
             <apex:column value="{!le.name}"  headerValue="Name"/> 
             <apex:column value="{!le.Phone}" headerValue="Phone"/>
             <apex:column value="{!le.Company}" headerValue="Company"/>
         </apex:dataTable> 
     </apex:pageBlock> 
Data Table with Custom Styles in Visualforce page.
Hi,In this post i am giving an example of <apex:dataTable> applying custom styles.
Controller Class:
public class TableController{
public List<Account> accList{get;set;}
public TableController(){
accList= new List<Account>();
accList= [select id,name,type,industry from Account];
}
}
Static Resources :
i upload an image from http://free-121d5f44d20-121d603d1c5-121ee2b8103.force.com/force2b/salesforceicons to static resources in salesforce.
Visualforce Page :
<apex:page controller="TableController" sidebar="false" wizard="true">
<style type="text/css">
.outBorder {
border:3px outset black;
}
.inBorder{
border-top:2px dotted blue;
border-left:2px dotted blue;
}
</style>
<apex:form >
<apex:pageBlock title="Data Table">
<apex:dataTable value="{!accList}" var="a" styleclass="outBorder" width="550px">
<apex:column styleclass="inBorder">
<apex:facet name="header">Image </apex:facet>
<apex:image value="{!$Resource.customerImage}"/>
</apex:column>
<apex:column styleclass="inBorder">
<apex:facet name="header">Account Name </apex:facet>
<apex:outputText >{!a.Name}</apex:outputText>
</apex:column>
<apex:column styleclass="inBorder">
<apex:facet name="header">Account type </apex:facet>
<apex:outputText >{!a.type}</apex:outputText>
</apex:column>
<apex:column styleclass="inBorder">
<apex:facet name="header">Account Industry </apex:facet>
<apex:outputText >{!a.industry}</apex:outputText>
</apex:column>
</apex:dataTable>
</apex:pageBlock>
</apex:form>
</apex:page>
Test Class:
@isTest
Public class DataTableWithStyles_Test {
static testmethod void testPageblockTable(){
//Test converage for the myPage visualforce page
PageReference pageref = Page.DataTableWithStyles;
Test.setCurrentPageReference(pageref);
// create an instance of the controller
TableController tc= new TableController();
}
}
Output:
 
No comments:
Post a Comment