0

我希望我已经正确地问了问题标题。让我解释一下我的问题 - 我正在通过 vb.net 代码(htmltablecell、htmltablerow ..)制作一个表格,这个表格没有填充 sql 查询并且工作正常。但是在一个表格单元中的这个表格中,我需要添加一个下拉列表,它需要一个完全不同的查询,并且应该在每一行上独立运行。所以代码如下

Sql = "..." rd = ExecuteReader(SqlCnn, Sql)

        Dim newcounter As Integer = 0
        While rd.Read()
            newcounter += 1
            Dim tr As New HtmlTableRow
            Dim td As New HtmlTableCell
            Dim chkbox As New CheckBox
            Dim id As String = rd("id") & ""
            If id.Length = 0 Then id = "new" & newcounter
            id &= "_" & rd("col1")
            chkbox.Style.Add("width", "20%")
            chkbox.ID = "new_id_" & id
            chkbox.Text = rd("col1")

            tr.Style.Add("width", "100%")
            td.Style.Add("width", "10%")
            td.Style.Add("text-align", "left")
            td.Controls.Add(chkbox)
            tr.Cells.Add(td)

            td = New HtmlTableCell
            td.Style.Add("width", "30%")
            Dim ddl As New dropdownlist
            ddl.Style.Add("width", "80%")
            ddl.ID = "a1_" & id
            --???????
            td.Controls.Add(ddl)
            tr.Cells.Add(td)

这 ???在代码中,下拉列表每次都应使用其自己的数据读取器和 while 循环和查询来填充。我怎样才能做到这一点?

4

1 回答 1

0

我会用 2 个查询来做到这一点;1 获取 ddl 数据, 1 获取实际记录。获取实际结果之前的ddl数据(ddlDataReader),创建ddl对象并将其添加到每一行。

像这样的东西应该可以工作:(我不做 VB.Net,所以你可能需要修复一些东西)

    Dim ddl As New dropdownlist
        ddl.Style.Add("width", "80%")
        ddl.ID = "a1_" & id
    While ddlDataReader.Read()
        ---add items to ddl
    end


    Dim newcounter As Integer = 0
    While rd.Read()
        newcounter += 1
        Dim tr As New HtmlTableRow
        Dim td As New HtmlTableCell
        Dim chkbox As New CheckBox
        Dim id As String = rd("id") & ""
        If id.Length = 0 Then id = "new" & newcounter
        id &= "_" & rd("col1")
        chkbox.Style.Add("width", "20%")
        chkbox.ID = "new_id_" & id
        chkbox.Text = rd("col1")

        tr.Style.Add("width", "100%")
        td.Style.Add("width", "10%")
        td.Style.Add("text-align", "left")
        td.Controls.Add(chkbox)
        tr.Cells.Add(td)

        td = New HtmlTableCell
        td.Style.Add("width", "30%")
        td.Controls.Add(ddl)
        tr.Cells.Add(td)

另一种方法是将 ddl 数据加载到数据表中,以便您可以多次循环访问它,然后在创建每一行时创建具有唯一 Id 的 ddl。

于 2010-03-03T18:36:44.570 回答