GridView多層嵌套和摺疊與展開

来源:http://www.cnblogs.com/shouce/archive/2016/03/10/5260462.html
-Advertisement-
Play Games

Insus.NET近段時間應朋友的要求,寫一個GridView多層嵌套和摺疊與展開。這個功能的GridView多層嵌套沒有問題,因為已經做了無限次數,但是摺疊與展開的功能,卻花上不少時間(網上找資料),雖找到資料可參考,還是瞭解明它,並修改適合自己程式使用。效果如下: 站點中多個頁面使用,因此Ins


Insus.NET近段時間應朋友的要求,寫一個GridView多層嵌套和摺疊與展開。這個功能的GridView多層嵌套沒有問題,因為已經做了無限次數,但是摺疊與展開的功能,卻花上不少時間(網上找資料),雖找到資料可參考,還是瞭解明它,並修改適合自己程式使用。效果如下:

 

站點中多個頁面使用,因此Insus.NET把它寫在一個用戶自定義控制項ASCX上

InsusMenu.ascx

<%@ Control Language="VB" AutoEventWireup="false" CodeFile="InsusMenu.ascx.vb" Inherits="AscxControls_InsusMenu" %>

<!--摺疊與展開的Javascript部分-->
<script type="text/javascript" language="javascript">
    function ShowHidde(sid, evt) {
        evt = evt || window.event;
        var target = evt.target || evt.srcElement;
        var objDiv = document.getElementById("div" + sid);
        objDiv.style.display = objDiv.style.display == "none" ? "block" : "none";
        target.title = objDiv.style.display == "none" ? "Show" : "Hide";
        var imgid = 'img' + sid;
        document.getElementById(imgid).src = objDiv.style.display == "none" ? "Image/+.gif" : "Image/-.gif";
    }
</script>
<!--第一層-->
<asp:GridView ID="GridViewYear" runat="server" Width="100%" AutoGenerateColumns="False"
    OnRowDataBound="GridViewYear_RowDataBound" ShowHeader="false" BorderWidth="0">
    <Columns>
        <asp:TemplateField>
            <ItemStyle BorderWidth="0" Height="25" />
            <ItemTemplate>

                 <!--下在這個綁定Eval("Year"),是為獲取唯一ID,如果你的記錄有一個主鍵的話,可以綁定主鍵的欄位名-->
                <img id='img<%# Eval("Year")%>' style="border: 0px;" src="Image/+.gif" onclick="ShowHidde('<%#Eval("Year")%>',event)" /> 
                              
                <!--下麵這個綁定,是第一層顯示的文字-->
                 <%# Eval("Year") & "年"%>
                <div id='div<%# Eval("Year")%>' style="display: none;">
                    
                    <!--第二層-->
                    <asp:GridView ID="GridViewMonth" runat="server" OnRowDataBound="GridViewMonth_RowDataBound" Width="100%" AutoGenerateColumns="False" ShowHeader="False" BorderWidth="0">
                        <Columns>
                            <asp:TemplateField>
                                <ItemStyle BorderWidth="0" Height="25" />
                                <ItemTemplate>
                                   <!--這部分的解釋,可參考上面。-->                                    
                                     <img id='img<%# Eval("Month")%>' style="border: 0px; padding-left: 20px;" src="Image/+.gif" onclick="ShowHidde('<%#Eval("Month")%>',event)" />
                                    <%# Eval("Month") & "月"%>
                                    <div id='div<%# Eval("Month")%>' style="display: none;">
                                       
                                        <!--第三層-->
                                         <asp:GridView ID="GridViewVideoFile" runat="server" Width="100%" AutoGenerateColumns="False"
                                            ShowHeader="False" BorderWidth="0">
                                            <Columns>
                                                <asp:TemplateField>
                                                    <ItemStyle BorderWidth="0" Height="25" />
                                                    <ItemTemplate>
                                                        <img style="border: 0px; padding-left: 40px; padding-right:5px; width: 16px; height: 16px; vertical-align: middle;" src="Image/m_file.png" /><asp:HyperLink ID="HyperLinkPlayer" runat="server" NavigateUrl='<%# "~/VideoPlayer.aspx?videokey=" & Eval("VideoLibrary_nbr")%>' Text='<%# Eval("OldFileName").Substring(0, Eval("OldFileName").LastIndexOf("."))%>' Target="_blank"></asp:HyperLink>
                                                    </ItemTemplate>
                                                </asp:TemplateField>
                                            </Columns>
                                        </asp:GridView>
                                    </div>
                                </ItemTemplate>
                            </asp:TemplateField>
                        </Columns>
                    </asp:GridView>
                </div>
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
</asp:GridView>

  

InsusMenu.ascx.vb

Imports System.Data
Imports Insus.NET

Partial Class AscxControls_InsusMenu
    Inherits System.Web.UI.UserControl

    '宣告實例
    Dim objVideoLibrary As New VideoLibrary()

    Protected Sub Page_Load(sender As Object, e As EventArgs) Handles Me.Load
        If Not IsPostBack Then
            Data_Binding()
        End If
    End Sub

    Private Sub Data_Binding()
        '從資料庫獲取數據,綁定在第一層的GridView
        Me.GridViewYear.DataSource = objVideoLibrary.GetYear()
        Me.GridViewYear.DataBind()
    End Sub

    '數據綁定在第二層的GridView
    Protected Sub GridViewYear_RowDataBound(sender As Object, e As GridViewRowEventArgs)


        Dim dvr As DataRowView = DirectCast(e.Row.DataItem, DataRowView)
        If e.Row.RowType = DataControlRowType.DataRow Then
            If e.Row.FindControl("GridViewMonth") IsNot Nothing Then
                Dim Gv As GridView = DirectCast(e.Row.FindControl("GridViewMonth"), GridView)
                objVideoLibrary.Year = ConvertData.ToSmallInt(dvr("Year"))
                Gv.DataSource = objVideoLibrary.GetMonthByYear()
                Gv.DataBind()
            End If
        End If
    End Sub

    '數據綁定在第三層的GridView
    Protected Sub GridViewMonth_RowDataBound(sender As Object, e As GridViewRowEventArgs)
        Dim dvr As DataRowView = DirectCast(e.Row.DataItem, DataRowView)
        If e.Row.RowType = DataControlRowType.DataRow Then
            If e.Row.FindControl("GridViewVideoFile") IsNot Nothing Then
                Dim Gv As GridView = DirectCast(e.Row.FindControl("GridViewVideoFile"), GridView)
                objVideoLibrary.Year = ConvertData.ToSmallInt(dvr("Year"))
                objVideoLibrary.Month = ConvertData.ToTinyInt(dvr("Month"))
                Gv.DataSource = objVideoLibrary.GetByYearAndMonth()
                Gv.DataBind()
            End If
        End If
    End Sub
End Class

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 異常信息處理是任何網站必不可少的一個環節,怎麼有效顯示,記錄,傳遞異常信息又成為重中之重的問題。本篇將基於上篇介紹的html2cancas截圖功能,實現mvc自定義全局異常處理。先看一下最終實現效果:http://yanweidie.myscloud.cn/Home/Index 閱讀目錄 我理解中好
  • OOD:面向對象設計(Object-Oriented Design,OOD)方法是OO方法中一個中間過渡環節。其主要作用是對OOA分析的結果作進一步的規範化整理,以便能夠被OOP直接接受。 OOP:面向對象編程(Object Oriented Programming,OOP,面向對象程式設計)是一種
  • Ext.Net是一個對ExtJS進行封裝了的.net控制項庫,可以在ASP.NET WebForm和MVC中使用。從今天開始記錄我的學習筆記,這是第一篇,今天學習瞭如何在WebForm中使用Ext.Net控制項庫。 下載Ext.Net 首先要去Ext.Net網站上下載Ext.Net,我先學習的是WebF
  • SSRS 報表 如何匿名查看 昨晚一直研究怎麼能匿名訪問報表然後給客戶看呢? 研究了好幾種辦法 我試過的分為三種,其中推薦我認為相對可控一點。 1.修改SSRS配置文件來禁止他驗證登陸用戶許可權 操作過的文章:SSRS匿名登錄 可以完全匿名訪問,因為我們系統是涉及到客戶要自己做報表的,所以這裡屏蔽了權
  • 關於C# DataTable 的一些操作 經常操作DATATABLE 對於一些不需要再通過sql 來重覆操作的 可以通過操作datatable來達到同樣的效果 方法一: 也是廣為人知的一種: YourDataTable.Columns.Remove("列名"); 但是這種情況只適合於去掉很少列的情況
  • SSRS 報表 如何加參數 連接上以後出現一個問題 就是給報表加上參數以後報表不斷刷新,跟上次那個報表刷新是同樣的問題。那麼下麵我們來解決一下。 1. 這是給報表添加預設參數進入頁面後就不斷的刷新刷新。 ReportParameter para = new ReportParameter("Repo
  • 背水一戰 Windows 10 之 UI: UI 設計概述, 啟動屏幕(閃屏), 屏幕方向
  • 出處:http://www.cnblogs.com/Interkey/ 偶然看到一個可以自刪除的程式,於是瞭解下如何實現。然後整理如下: 思路: 在.NET程式中,因為運行中的程式是受系統保護的,不能自己刪除自身的,所以自刪除的思路: 在關閉本程式之前啟動新的進程打開另一個程式,調用這個程式來刪除原
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...