Repeater中巢狀使用Repeater
Repeater中巢狀使用Repeater。如圖
本例使用 vs.net 2008(C#)編寫。來自 admin10000.com
後臺CS程式碼
protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { this.dtCategory = GetCategoryTable(); this.dtProduct = GetProductTable(); rptCategoryList.DataSource = dtCategory; rptCategoryList.DataBind(); } } // 準備一張分類表 DataTable GetCategoryTable() { DataTable dt = new DataTable(); dt.Columns.Add("CategoryId", typeof(int)); dt.Columns.Add("CategoryTitle", typeof(string)); for (int i = 1; i <= 3; i++) { DataRow row = dt.NewRow(); row["CategoryId"] = i; row["CategoryTitle"] = "分類名字 " + i + ""; dt.Rows.Add(row); } return dt; } // 準備一張產品表 DataTable GetProductTable() { DataTable dt = new DataTable(); dt.Columns.Add("ProductTitle", typeof(string)); dt.Columns.Add("CategoryId", typeof(int)); for (int i = 1; i <= 9; i++) { DataRow row = dt.NewRow(); row["ProductTitle"] = "產品名字 " + i + ""; if (i > 6) row["CategoryId"] = 3; else if (i > 3) row["CategoryId"] = 2; else row["CategoryId"] = 1; dt.Rows.Add(row); } return dt; } // 獲取某個類別的產品 DataTable GetProductTable(int categoryId) { DataView dv = this.dtProduct.DefaultView; dv.RowFilter = " CategoryId=" + categoryId + " "; return dv.ToTable(); } protected void rptCategoryList_ItemDataBound(object sender, RepeaterItemEventArgs e) { if (e.Item.ItemType == ListItemType.AlternatingItem || e.Item.ItemType == ListItemType.Item) { DataRowView drv = (DataRowView)e.Item.DataItem; Literal ltlTitle = (Literal)e.Item.FindControl("ltlTitle"); ltlTitle.Text = drv["CategoryTitle"].ToString(); Repeater rptProductList = (Repeater)e.Item.FindControl("rptProductList"); rptProductList.DataSource = GetProductTable(Convert.ToInt32(drv["CategoryId"])); rptProductList.DataBind(); } } protected void rptProductList_ItemDataBound(object sender, RepeaterItemEventArgs e) { if (e.Item.ItemType == ListItemType.AlternatingItem || e.Item.ItemType == ListItemType.Item) { DataRowView drv = (DataRowView)e.Item.DataItem; Literal ltlTitle = (Literal)e.Item.FindControl("ltlTitle"); ltlTitle.Text = drv["ProductTitle"].ToString(); } }
前臺aspx程式碼
<form id="form1" runat="server"> <div> <asp:Repeater ID="rptCategoryList" runat="server" OnItemDataBound="rptCategoryList_ItemDataBound"> <ItemTemplate> <div class="listBox"> <div class="title"> <asp:Literal ID="ltlTitle" runat="server"></asp:Literal></div> <div class="content"> <ul> <asp:Repeater ID="rptProductList" runat="server" OnItemDataBound="rptProductList_ItemDataBound"> <ItemTemplate> <li> <asp:Literal ID="ltlTitle" runat="server"></asp:Literal> </li> </ItemTemplate> </asp:Repeater> </ul> </div> </div> </ItemTemplate> </asp:Repeater> </div> </form>
下載程式碼示例: PageDemo.RAR
相關文件: Repeater控制元件的分頁實現 Repeater控制元件實現編輯、更新、刪除操作 Repeater多行間隔顯示分隔符的方法
相關文章
- repeater中巢狀放入RadioButtonList巢狀
- C#控制元件之Repeater控制元件使用C#控制元件
- 動態綁資料(Repeater控制元件控制元件
- 流量回放框架 jvm-sandbox-repeater 實踐二框架JVM
- ASP.NET Web Forms – Repeater 控制元件簡介ASP.NETWebORM控制元件
- [jvm-sandbox-repeater 學習筆記][入門使用篇] 2 配置說明JVM筆記
- iOS block巢狀block中weakify的使用iOSBloC巢狀
- es中如何使用巢狀物件查詢巢狀物件
- 通用流量錄製回放工具 jvm-sandbox-repeater 嚐鮮 (四)——新版帶介面 console 的使用JVM
- Vue中的巢狀路由Vue巢狀路由
- [jvm-sandbox-repeater 學習筆記][原理說明篇] 1 錄製流程JVM筆記
- [jvm-sandbox-repeater 學習筆記][原理說明篇] 2 回放流程JVM筆記
- 流量錄製回放工具jvm-sandbox-repeater入門篇——服務部署JVM
- ViewPager巢狀fragment簡單使用Viewpager巢狀Fragment
- 流量錄製回放工具jvm-sandbox-repeater入門篇——錄製和回放JVM
- jvm-sandbox-repeater 錄製存在自定義型別 java 方法時報錯 ClassNotFoundJVM型別Java
- sql server中巢狀事務*SQLServer巢狀
- JavaScript中if巢狀assert的方法JavaScript巢狀
- 對比SQL中簡單巢狀查詢與非巢狀查詢CFSQL巢狀
- Fragment巢狀FragmentViewPager 正常使用姿勢Fragment巢狀Viewpager
- javafx和swing巢狀使用的方法Java巢狀
- Linux的中斷可以巢狀嗎?Linux巢狀
- 使用swiper.js建立巢狀的swiperJS巢狀
- Angular 裡使用巢狀 Form 的步驟Angular巢狀ORM
- 列表巢狀操作巢狀
- vue路由巢狀Vue路由巢狀
- Confluence 6 啟用巢狀使用者組巢狀
- 【BUG系列】Fragment中巢狀Fragment,不顯示Fragment巢狀
- js中的函式巢狀和閉包JS函式巢狀
- SQL Server中存在真正的“事務巢狀”SQLServer巢狀
- SCSS 巢狀屬性CSS巢狀
- SCSS 巢狀規則CSS巢狀
- 展開巢狀列表巢狀
- Locust 任務巢狀巢狀
- Oracle 巢狀表(轉)Oracle巢狀
- 巢狀類遞迴巢狀遞迴
- vue(19)巢狀路由Vue巢狀路由
- 巢狀子查詢巢狀
- Blazor巢狀傳遞Blazor巢狀