0

実行時に列数が変化する listView を作成する必要があります。

私のaspxページコード:

<asp:ListView runat="server" ID="ReportListView">
    <LayoutTemplate>
        <table>
            <tr>
                <asp:PlaceHolder runat="server" ID="itemPlaceHolder" />
            </tr>
        </table>
    </LayoutTemplate>
    <ItemTemplate>
        <table>
            <tr>
                <asp:PlaceHolder runat="server" ID="itemPlaceHolder1" />
            </tr>
        </table>
    </ItemTemplate>
</asp:ListView>

ItemTemplate では、コード ビハインドから列を動的にバインドする必要があります。

私の .cs ページ コード:

SqlCommand cmd = new SqlCommand(query);

    using (SqlConnection con = new SqlConnection(conString))
    {
        using (SqlDataAdapter sda = new SqlDataAdapter())
        {
            cmd.Connection = con;
            sda.SelectCommand = cmd;
            using (DataSet ds = new DataSet())
            {
                sda.Fill(ds);

                ReportListView.DataSource = ds;
                ReportListView.DataBind();
            }
        }
    }

    foreach (ListViewDataItem listItem in ReportListView.Items)
    {
        PlaceHolder plc = (PlaceHolder)listItem.FindControl("itemPlaceHolder1");
        if (plc != null)
        {
                Literal ltrl = new Literal();
                ltrl.Text = "<td>" + listItem.DataItem + "</td>";
                plc.Controls.Add(ltrl);

        }
    }

しかし、ブラウザには何も返されません。エラーも出力もありません....

助言がありますか......

4

3 に答える 3

0

列の動的セットを使用してテーブルを作成した後である場合は、を使用GridViewして独自の を作成してみませんColumnsGeneratorか? 作成する列のセットを返す which を実装するクラスを作成し、それをプロパティIAutoFieldGeneratorに割り当てます。GridView.ColumnsGenerator

本当に と テンプレートの方法を使いたい場合は、これを継承して に割り当てるListViewクラスを作成できます。IBindableTemplateListView.ItemTemplate

于 2013-01-08T08:19:09.153 に答える
0

私はそれについて投稿を書きました: http://start-coding.blogspot.com/2013/06/dynamic-columns-in-listview.html

ItemDataBound イベントで、次のようにします (他のコントロールまたは LoadControl に置き換えることができます)。

private void dynamicPopulateRow(HtmlTableRow row, System.Data.DataRowView drv, int iGeneration)
{
    if (row != null)
    {
        // http://www.pcreview.co.uk/forums/do-enumerate-all-columns-dataviewrow-t1244448.html
        foreach (DataColumn dc in drv.Row.Table.Columns)
        {
            string sEmployeeID = drv["LoginID"].ToString();

            if (dc.ColumnName.Equals("LoginID"))
            {
                // http://msdn.microsoft.com/en-US/library/e5daxzcy(v=vs.80).aspx
                // Define a new HtmlTableCell control.
                HtmlTableCell cell = new HtmlTableCell("td");

                // Create the text for the cell.
                cell.Controls.Add(new LiteralControl(Convert.ToString(drv[dc.ColumnName])));
                cell.ColSpan = dc.ColumnName.Equals("LoginID") ? I_COLSPAN - iGeneration : 1;

                // Add the cell to the HtmlTableRow Cells collection. 
                row.Cells.Add(cell);
            }
            else if (!(dc.ColumnName.Equals("GENERATION") ||
                        dc.ColumnName.Equals("hierarchy") ||
                        dc.ColumnName.Equals("rowNo") ||
                        dc.ColumnName.Equals("EmployeeID")))
            {
                // http://msdn.microsoft.com/en-US/library/e5daxzcy(v=vs.80).aspx
                // Define a new HtmlTableCell control.
                HtmlTableCell cell = new HtmlTableCell("td");

                bool bIsNull = drv[dc.ColumnName] is System.DBNull;

                Literal ltrl = new Literal();
                ltrl.Text += "<input type=\"checkbox\" name=\"" + dc.ColumnName + "\"" +
                                (bIsNull ? "" : " value=" + drv[dc.ColumnName].ToString()) +
                                " id=\"" + sEmployeeID + "~" + dc.ColumnName.Replace(" ", "_") + "\"" +//will be retrieved later
                                " onclick=\"didModify(this)\" " +
                                (bIsNull ? " disabled" : "") +
                                (!bIsNull && ((int)drv[dc.ColumnName]) > 0 ? " checked>" : ">");

                cell.Controls.Add(ltrl);
                // Add the cell to the HtmlTableRow Cells collection. 
                row.Cells.Add(cell);
            }
            else
            {
                //other rows
            }
        }
    }
}
于 2013-06-05T07:30:49.123 に答える
-1
protected void methodone()
{
  SqlCommand cmd = new SqlCommand(query);
  SqlConnection con = new SqlConnection(conString);
  DataSet ds = new DataSet()
  try
  {

  SqlDataAdapter sda = new SqlDataAdapter(cmd,con);
  sda.Fill(ds);
  ReportListView.DataSource = ds;
  ReportListView.DataBind();
}
catch(SqlException ex)
{
  throw;
}
finally
{
  if(con!=null)
   con.close();
}
}

//and dont foreget to call the methodone at the page load ..wherever ..
于 2013-01-08T08:34:23.190 に答える