• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

ASP.NET中使用GridView实现分级显示的代码

asp 搞代码 4年前 (2022-01-03) 27次浏览 已收录 0个评论

在实际项目开发中,往往需要用到在页面上对列表的项目实现分级显示,在 ASP.NET中没有现成的控件。

在实际项目开发中,我找到了一种利用GridView实现分级效果的方法,最终

以下是实现代码:
Aspx页面

代码如下:
Width=”100%” AllowPaging=”true” PageSize=”10″>

‘/>

OnRowDataBound=”doOnRowDataBoundOrders”>

DataFormatString=”{0:d}”>

DataFormatString=”{0:d}”>

‘/>

AutoGenerateColumns=”false”>

后台代码

代码如下:
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
If Not IsPostBack Then
BindGridView()
End If
End Sub
‘1.首先找出Customers数据
Public Sub BindGridView()
Dim strSQL As String = “SELECT * FROM Customers”
Dim dtTable As DataTable = GetDataTable(strSQL)
sCount = dtTable.Rows.Count
Me.GridView1.DataSource = dtTable
Me.GridView1.DataBind()
End Sub
‘Customers数据绑定时要做的事情
Protected Sub GridView1_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles GridView1.RowDataBound
If e.Row.RowType = DataControlRowType.DataRow Then
Dim HCustomerID As String = CType(e.Row.FindControl(“HCustomerID”), HiddenField).Value
Dim TRCustomers As HtmlTableRow = CType(e.Row.FindControl(“TRCustomers”), HtmlTableRow)
If HCustomerID.Trim.Length > 0 Then
‘鼠标移过时变换css样式。
e.Row.Attributes.Add(“onmouseover”, “currentcolor=this.className;this.className=’MouseOver’;”)
e.Row.Attributes.Add(“onmouseout”, “this.className=currentcolor;”)
‘找出此Customer的所有Orders
Dim strSQL As String = “SELECT * FROM Orders WHERE CustomerID='” & HCustomerID & “‘”
Dim dtTable As DataTable = GetDataTable(strSQL)
Dim imgFlag As Image = CType(e.Row.FindControl(“imgFlag”), Image)
If dtTable.Rows.Count > 0 Then
Dim GridViewOrders As GridView = CType(e.Row.FindControl(“GridViewOrders”), GridView)
GridViewOrders.DataSource = dtTable
GridViewOrders.DataBind()
‘设置点击某行时的Javascript
Dim strScript As New StringBuilder
strScript.Append(“var obj = document.getElementById(‘” & TRCustomers.ClientID & “‘);”)
strScript.Append(“var objimg = document.getElementById(‘” & imgFlag.ClientID & “‘);”)
strScript.Append(“if (obj.style.display == ‘none’) {“)
strScript.Append(” obj.style.display = ”;”)
strScript.Append(” objimg.src = ‘images/up.gif’;”)
strScript.Append(“}else{“)
strScript.Append(” obj.style.display = ‘none’;”)
strScript.Append(” objimg.src = ‘images/dn.gif’;”)
strScript.Append(“}”)
e.Row.Attributes.Add(“onclick”, strScript.ToString)
Else
imgFlag.ImageUrl = “~/images/up.gif”
End If
End If
End If
End Sub
Protected Sub doOnRowDataBoundOrders(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs)
If e.Row.RowType = DataControlRowType.DataRow Then
Dim HOrderID As String = CType(e.Row.FindControl(“HOrderID”), HiddenField).Value
Dim TROrders As HtmlTableRow = CType(e.Row.FindControl(“TROrders”), HtmlTableRow)
If HOrderID.Trim.Length > 0 Then
‘鼠标移过时变换css样式。
e.Row.Attributes.Add(“onmouseover”, “currentcolor=this.className;this.className=’MouseOver’;”)
e.Row.Attributes.Add(“onmouseout”, “this.className=currentcolor;”)
‘找出此Order的所有Order Details
Dim strSQL As String = “SELECT Products.ProductName, [Order Details].UnitPrice, [Order Details].Quantity, [Order Details].UnitPrice * [Order Details].Quantity AS OPrice, [Order Details].Discount, ” & _
“([Order Details].UnitPrice * [Order Details].Quantity) * (1.00 – [Order Details]来源gao.dai.ma.com搞@代*码网.Discount) AS PPrice, Products.QuantityPerUnit ” & _
“FROM [Order Details] INNER JOIN Products ON [Order Details].ProductID = Products.ProductID ” & _
“WHERE OrderID='” & HOrderID & “‘”
Dim dtTable As DataTable = GetDataTable(strSQL)
Dim imgFlag1 As Image = CType(e.Row.FindControl(“imgFlag1”), Image)
If dtTable.Rows.Count > 0 Then
Dim GridViewOrderDetails As GridView = CType(e.Row.FindControl(“GridViewOrderDetails”), GridView)
GridViewOrderDetails.DataSource = dtTable
GridViewOrderDetails.DataBind()
‘设置点击某行时的Javascript
Dim strScript As New StringBuilder
strScript.Append(“var obj = document.getElementById(‘” & TROrders.ClientID & “‘);”)
strScript.Append(“var objimg = document.getElementById(‘” & imgFlag1.ClientID & “‘);”)
strScript.Append(“if (obj.style.display == ‘none’) {“)
strScript.Append(” obj.style.display = ”;”)
strScript.Append(” objimg.src = ‘images/up.gif’;”)
strScript.Append(“}else{“)
strScript.Append(” obj.style.display = ‘none’;”)
strScript.Append(” objimg.src = ‘images/dn.gif’;”)
strScript.Append(“}”)
e.Row.Attributes.Add(“onclick”, strScript.ToString)
End If
End If
End If
End Sub

以上就是ASP.NET中使用GridView实现分级显示的代码的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:ASP.NET中使用GridView实现分级显示的代码

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址