为了账号安全,请及时绑定邮箱和手机立即绑定

GridView多层嵌套和折叠与展开

标签:
JavaScript

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")%>'  class="lazyload" src="" data-original="Image/+.gif" onclick="ShowHidde('<%#Eval("Year")%>',event)" />                                               <!--下面这个绑定,是第一层显示的文字-->                 <%# Eval("Year") & "年"%>                <div id='div<%# Eval("Year")%>' >                                        <!--第二层-->                    <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")%>'  class="lazyload" src="" data-original="Image/+.gif" onclick="ShowHidde('<%#Eval("Month")%>',event)" />                                    <%# Eval("Month") & "月"%>                                    <div id='div<%# Eval("Month")%>' >                                                                               <!--第三层-->                                         <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;" class="lazyload" src="" data-original="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.DataImports Insus.NETPartial 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 SubEnd Class

  

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消