Modal Popup from Repeater


ASP.NET The repeater is data-bound list control that allows custom layout by repeating a specified template for each item displayed in the list. It is more similar to ASP.NET GridView power, but it will enable complete control.
In this post, I will show you how to open a Modal popup from the repeater. The code is straightforward and easy to understand.

<%@ Page Language="C#" AutoEventWireup="true"  
CodeFile="RepeaterModalPopup.aspx.cs"  
 Inherits="RepeaterModalPopup" %>  
  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
<html xmlns="http://www.w3.org/1999/xhtml">  
<head runat="server">  
 <title>Untitled Page</title>  
  
 <script type="text/jscript">  
  function ShowModalWindow(Id)  
               {  
window.showModalDialog("Details.aspx?accountNo="+ Id +"","",  
"status:no;dialogWidth:800px;  
dialogHeight:570px;help:no;center:yes;resizable:no;scroll:yes;status:no;");  
               }  
  
 </script>  
  
</head>  
<body>  
 <form id="form1" runat="server">  
     <div>  
         <asp:Repeater ID="Repeater1" runat="server">  
             <HeaderTemplate>  
                 <table border="1" width="100%">  
                     <tr>  
                         <th>  
                             COL1</th>  
                         <th>  
                             COL2</th>  
                         <th>  
                             COL3</th>  
                         <th>  
                             COL4</th>  
                     </tr>  
             </HeaderTemplate>  
             <ItemTemplate>  
                 <tr>  
                     <td>  
                         <a href='Details.aspx?FrromTest=true  
&accountno=<%# DataBinder.Eval(Container.DataItem,"accountNo")  
%>&TypeDesc=<%# DataBinder.Eval(Container.DataItem,"CompanyName") %>'>  
                             <%# DataBinder.Eval(Container.DataItem, "CompanyName")%>  
                         </a>  
                     </td>  
                     <td>  
                         <a href='#'  
onclick="ShowModalWindow('<%# DataBinder.Eval(Container.DataItem,"accountNo") %>');">  
                             <%# DataBinder.Eval(Container.DataItem, "CompanyName")%>  
                         </a>  
                     </td>  
                     <td>  
                         <%# DataBinder.Eval(Container.DataItem,"Address") %>  
                     </td>  
                     <td>  
                         This is a free column</td>  
                 </tr>  
             </ItemTemplate>  
             <FooterTemplate>  
                 </table>  
             </FooterTemplate>  
         </asp:Repeater>  
     </div>  
 </form>  
</body>  
</html>  


using System;  
using System.Data;  
using System.Configuration;  
using System.Collections;  
using System.Web;  
using System.Web.Security;  
using System.Web.UI;  
using System.Web.UI.WebControls;  
using System.Web.UI.WebControls.WebParts;  
using System.Web.UI.HtmlControls;  

public partial class RepeaterModalPopup : System.Web.UI.Page  
{  
 protected void Page_Load(object sender, EventArgs e)  
 {  

     Repeater1.DataSource = GetDataSet();  
     Repeater1.DataBind();  
 }  
 public DataSet GetDataSet()  
 {  
     DataSet ds = new DataSet();  
     DataTable dt = new DataTable("Company");  
     DataRow dr;  
     dt.Columns.Add(new DataColumn("accountNo", typeof(Int32)));  
     dt.Columns.Add(new DataColumn("CompanyName", typeof(string)));  
     dt.Columns.Add(new DataColumn("Address", typeof(string)));  
     for (int i = 0; i <= 10; i++)  
     {  
         dr = dt.NewRow();  
         dr[0] = i;  
         dr[1] = "Company" + i + Environment.NewLine + "Title" + i;  
         dr[2] = "Address" + i + Environment.NewLine + "Title" + i;  
         dt.Rows.Add(dr);  
     }  
     ds.Tables.Add(dt);  
     return ds;  
 }  
}  

Details.aspx

public partial class Details : System.Web.UI.Page  
{  
 protected void Page_Load(object sender, EventArgs e)  
 {  
     
     DataView dv = new DataView(GetDataSet().Tables[0]);  
     dv.RowFilter = "accountno='" + Request.QueryString["accountno"].ToString() + "'";  
     GridView1.DataSource = dv;  
     GridView1.DataBind();  

 }  
}
Next Post Previous Post
No Comment
Add Comment
comment url