使用来自服务器的数据填充ListView

时间:2009-05-15 08:39:18

标签: asp.net listview

我的结帐页面上有一个ListView,其中包含一个ItemTemplate,用于构建客户订购的商品表。我想在表格的页脚中添加一个总计,我有以下标记:

<asp:ListView ID="lvOrderSummary" runat="server">
  <LayoutTemplate>
    <table id="tblOrderSummary">
      <tr>
        <td><b>Title</b></td>
        <td><b>Cost</b></td>
      </tr>
      <asp:PlaceHolder ID="itemPlaceholder" runat="server" />
      <tr>
        <td><b>Total Cost:</b></td>
        <td><%# GetTotalCost().ToString()%></td>
      </tr>
    </table>
  </LayoutTemplate>
  <ItemTemplate>
    <tr>
      <td><%#Eval("Title") %></td>
      <td><%#Eval("Cost") %> </td>
    </tr>
  </ItemTemplate>
</asp:ListView>

我有一个名为GetTotalCost的服务器端方法,它返回我需要的值。我遇到的问题是永远不会调用此方法。 我也尝试过而不是使用:

<td><%# GetTotalCost().ToString()%></td>

我尝试过使用

<td id="tdTotal" runat="server"></td>
---------------
protected void Page_Load(object sender, EventArgs e)
{
  if (!Page.IsPostBack)
  {
    TableCell td = ((TableCell)this.FindControl("lvOrderSummary_tdTotal"));
  }
}

2 个答案:

答案 0 :(得分:2)

检查this article以获取如何在ListView中显示总数的示例。

基本上,您可以在布局模板中添加标签:

<asp:ListView ID="lvOrderSummary" runat="server"
  OnPreRender="lvOrderSummary_PreRender" ...>

  <LayoutTemplate>
    ...
    <td><asp:Label ID="lblTotalCost" runat="server" Text="Total"/></td>
    ..
  </LayoutTemplate></asp:ListView>

然后在PreRender事件处理程序中设置标签的文本:

protected void lvOrderSummary_PreRender(object sender, EventArgs e)
{
   Label lbl = lvOrderSummary.FindControl("lblTotalCost") as Label;
   lbl.Text = GetTotalCost().ToString();
}

答案 1 :(得分:0)

Try

        Dim strcon As String = "Data Source=.\SQLEXPRESS;AttachDbFilename=D:\webarticles\App_Data\mydatabase.mdf;Integrated Security=True;User Instance=True"
        Dim con As New SqlConnection(strcon)
        con.Open()
        Dim da As SqlDataAdapter
        Dim ds As New DataSet
        Dim sqlstring As String = "SELECT * FROM tblstudent "
        da = New SqlDataAdapter(sqlstring, con)
        da.Fill(ds)
        DetailsView1.DataSource = ds.Tables(0)
        DetailsView1.DataBind()

    Catch ex As Exception
        MsgBox("There is some Error")

    End Try

另一个数据处理控件是DetailsView控件,它使您能够从关联的数据源一次显示,删除,编辑,插入单个记录。 DetailsView控件不支持排序。默认情况下,DetailsView控件在其自己的行上显示记录的每个字段。