TreeView扩展错误的节点

时间:2014-05-20 14:57:51

标签: asp.net vb.net treeview

我在VB.NET/ASP.NET应用程序中有一个TreeView。

当页面加载时,TreeView将以编程方式填充。但是,当我尝试扩展节点时,它正在扩展错误的节点。

示例:我有一个包含5个孩子的节点。节点一和二有孩子,当我尝试扩展节点二时,它扩展节点一,当我尝试扩展节点一时,它也扩展节点一。

我尝试重新组织TreeView的结构,并尝试逐个添加节点,但仍然没有运气。

编辑: 以下是我的TreeView中的相关代码:

For Each V2MaterialRow In DS.Tables("AllinOne").Rows
                            connection.Open()
                            command = New SqlCommand("Select FormName from ISO where PageTitle='Material Details'", connection)
                            Dim FormName As String = command.ExecuteScalar()
                            connection.Close()
                            V2MaterialNode = New TreeNode
                            V2MaterialNode.ToolTip = "V2 Material Details"
                            V2MaterialNode.Text = FormName & "  " & V2MaterialRow("Version")
                            V2MaterialNode.Value = V2MaterialRow("Qno")
                            V2MaterialNode.ShowCheckBox = True
                            V2MaterialNode.NavigateUrl = "V2MaterialDetails.aspx?text=" + V2MaterialRow("Qno")
                            V2MaterialNode.Target = "_blank"
                            node.ChildNodes.Add(V2MaterialNode)
                            connection.Open()
                            command = New SqlCommand("Select * from Specallinone where qno='" + V2MaterialRow("Qno") + "'", connection)
                            datareader = command.ExecuteReader()
                            If datareader.HasRows = False Then
                                datareader.Close()
                                For Each PurchaseOrderRow In DS.Tables("PurchaseOrder").Rows
                                    PurchaseOrderNode = New TreeNode
                                    PurchaseOrderNode.ToolTip = "Purchase Order"
                                    PurchaseOrderNode.Text = "Purchase Order - " + PurchaseOrderRow("supplier") + " " + PurchaseOrderRow("Ordernumber")
                                    PurchaseOrderNode.Value = PurchaseOrderRow("Qno")
                                    PurchaseOrderNode.NavigateUrl = "PurchaseOrder.aspx?qno=" + PurchaseOrderRow("Qno") + "&Jobno=" + PurchaseOrderRow("JobNumber") + "&Orderno=" + PurchaseOrderRow("Ordernumber") + "&text=" + Replace(PurchaseOrderRow("supplier"), "&", "$") + ""
                                    PurchaseOrderNode.Target = "_blank"
                                    V2MaterialNode.ChildNodes.Add(PurchaseOrderNode)
                                Next

                            Else
                                datareader.Close()
                            End If
                            connection.Close()
                            For Each LabelRow As DataRow In DS.Tables("AllinOne").Rows
                                Dim Labelnode = New TreeNode
                                Labelnode.ToolTip = "PO Labels"
                                Labelnode.Text = "PO Labels"
                                Labelnode.Value = LabelRow("Qno")
                                'Labelnode.ShowCheckBox = True
                                Labelnode.NavigateUrl = "GeneratePOLabels.aspx?text=" + LabelRow("Qno")
                                Labelnode.Target = "_blank"
                                Try
                                    connection.Open()
                                    command = New SqlCommand("Select * from purchaseorder where qno='" + LabelRow("Qno") + "' and Jobnumber<>''", connection)
                                    datareader = command.ExecuteReader()
                                    If datareader.HasRows = False Then
                                        datareader.Close()
                                        Exit For
                                    Else
                                        datareader.Close()
                                        V2MaterialNode.ChildNodes.Add(Labelnode)
                                    End If
                                Catch ex As Exception
                                    Messagebox.Show("Error in Dispalying the Labels...")
                                Finally
                                    connection.Close()
                                End Try
                            Next

                        Next
                        For Each MPORow In DS.Tables("ManualPO").Rows
                            Dim Supplier As String
                            connection.Open()
                            command = New SqlCommand("Select Distinct Supplier from ManualPurchaseOrder where ManualDetailsId='" + MPORow("ManualDetailsId").ToString + "' ", connection)
                            datareader = command.ExecuteReader()
                            While datareader.Read()
                                Supplier = Supplier + datareader.Item("Supplier") + ","
                            End While
                            datareader.Close()
                            connection.Close()
                            MPONode = New TreeNode
                            MPONode.Value = MPORow("ManualDetailsId")
                            MPONode.Text = "Manual PO " & MPORow("ManualDetailsId") & " Supplier:" & Supplier.ToString
                            Supplier = ""
                            node.ChildNodes.Add(MPONode)

                            Dim ManualPODetailsDa As New SqlDataAdapter("Select distinct supplier,Jobnumber,ordernumber,Qno from PurchaseOrder where Ordernumber in (Select Distinct OrderNumber From ManualPurchaseOrder where ManualDetailsId = '" + MPORow("ManualDetailsId") + "') ", connection)
                            Dim ManualPODetailsDs As New DataSet
                            ManualPODetailsDa.Fill(ManualPODetailsDs)
                            For Each ManualPODetailsDR As DataRow In ManualPODetailsDs.Tables(0).Rows
                                MPODNode = New TreeNode
                                MPODNode.Value = ManualPODetailsDR("OrderNumber")
                                MPODNode.Text = "Purchase Order - " + ManualPODetailsDR("supplier") + " " + ManualPODetailsDR("Ordernumber")
                                MPODNode.NavigateUrl = "PurchaseOrder.aspx?qno=" + ManualPODetailsDR("Qno") + "&Jobno=" + ManualPODetailsDR("JobNumber") + "&Orderno=" + ManualPODetailsDR("Ordernumber") + "&text=" + Replace(ManualPODetailsDR("supplier"), "&", "$") + ""
                                MPODNode.Target = "_blank"
                                MPONode.ChildNodes.Add(MPODNode)
                            Next
                    Next
                    For Each Takeoffrow In DS.Tables("AllinOne").Rows
                        connection.Open()
                        command = New SqlCommand("Select FormName from ISO where PageTitle='Take-Off-Sheets'", connection)
                        Dim FormName As String = command.ExecuteScalar()
                        TakeOffNode = New TreeNode
                        TakeOffNode.ToolTip = "Take Off Sheets"
                        TakeOffNode.Text = FormName & "  " & Takeoffrow("Version")
                        TakeOffNode.Value = Takeoffrow("Qno")
                        TakeOffNode.ShowCheckBox = True
                        TakeOffNode.NavigateUrl = "TakeOffSheet.aspx?text=" + Takeoffrow("Qno")
                        TakeOffNode.Target = "_blank"
                        node.ChildNodes.Add(TakeOffNode)
                        command = New SqlCommand("Select count(*) from ManualTakeOffSheet where srecid in (Select Distinct Srecid from Specdetails where Quoteno='" + Takeoffrow("Qno") + "')", connection)
                        Dim MTS As Integer = 0
                        MTS = command.ExecuteScalar()
                        connection.Close()
                        If MTS > 0 Then
                            Dim ManualTakeoffnode As New TreeNode
                            ManualTakeoffnode.ToolTip = "Manual Take Off Sheets"
                            ManualTakeoffnode.Text = "Manual Take Off Sheets" & "  " & Takeoffrow("Version")
                            ManualTakeoffnode.Value = Takeoffrow("Qno")
                            ManualTakeoffnode.NavigateUrl = "ManualTakeOffSheet.aspx?text=" + Takeoffrow("Qno")
                            ManualTakeoffnode.Target = "_blank"
                            TakeOffNode.ChildNodes.Add(ManualTakeoffnode)
                        End If
                    Next

1 个答案:

答案 0 :(得分:1)

有时,如果您的节点与另一个节点共享相同的值 - 可能会发生意外行为(单击另一个节点时会打开一个节点)

节点值必须是唯一的

调试代码并确保所有节点都具有唯一值。

该值将存储在node.Value

在您的情况下,从表中填充node.Value

确保TakeOffNode.Value = Takeoffrow("Qno")不等于MPODNode.Value = ManualPODetailsDR("OrderNumber")