0

いくつかの異なるコントロールを持つリストビューがあります。クエリの特定のフィールドをコントロールの特定の部分にバインドする必要があります。テーブルには、フレンド ID とファーストネームが含まれています。URL の末尾にフレンド ID を付けたい。ラベルのテキストにファーストネームを入れたい。クエリで複数の友人が返されます。リストビューは、すべてを別の行に表示する必要があります。ここに私が持っているものがありますが、これは明らかに正しくありません。

<asp:ListView ID="lvFriends" runat="server">
    <LayoutTemplate>
    <ul ID="itemPlaceholderContainer" runat="server" style="">
        <li ID="itemPlaceholder" runat="server" />
    </ul>
</LayoutTemplate>
    <ItemTemplate>
        <li>
            <div style="float:left;">
                <a id="A1" href='<%# ResolveUrl(String.Format("~/UserPages/FriendsPages/FriendsProfile.aspx?friend={0}", Container.DataItem)) %>' runat="server"><asp:Image ID="ImageButton1" ImageUrl='<%# ResolveUrl(String.Format("~/UserPages/FriendsPages/FriendsThumbImage.aspx?friend={0}", Container.DataItem)) %>' runat="server" /></a>
        </div>

            <div style="margin-left:300px;">
        <ul>
            <li><asp:Label ID="FirstNameLabel" runat="server" Text='<%# Eval("FriendFN") %>' /></li>
        </ul>
    </div>
        </li>
    <div style="clear:both;"></div>
    </ItemTemplate>
<ItemSeparatorTemplate><br /></ItemSeparatorTemplate>
</asp:ListView>

コードビハインド:

string strCon = System.Web.Configuration.WebConfigurationManager.ConnectionStrings["SocialSiteConnectionString"].ConnectionString;
using (SqlConnection conn = new SqlConnection(strCon))
{
    using (SqlCommand cmd = conn.CreateCommand())
    {
        conn.Open();
        cmd.CommandText = "SELECT * from [Friends] WHERE [UserId] = @UserId";
        cmd.Parameters.AddWithValue("@UserId", User.Identity.Name);

        DataTable dtFriends = new DataTable();
        dtFriends.Columns.Add("FriendId");
        dtFriends.Columns.Add("FriendFN");

        SqlDataReader nwReader = cmd.ExecuteReader();
        while (nwReader.Read())
        {
            string RdFriendId = nwReader["FriendId"].ToString().ToLower();
            string RdFriendFN = nwReader["FriendFirstName"].ToString().ToLower();

            dtFriends.Rows.Add(new object[] {RdFriendId, RdFriendFN});
        }
        nwReader.Close();
        Session.Add("FriendsTable", dtFriends);

        conn.Close();
        lvFriends.DataSource = dtFriends;
        lvFriends.DataBind();
    }
}
4

1 に答える 1

0

代わりにリピーター コントロールの使用を検討します。

于 2009-04-15T02:23:43.910 に答える