2009-04-14 9 views
0

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

<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> 

BEHIND CODE:

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(); 
    } 
} 

答えて

0

私の代わりにRepeaterコントロールを使用してになります。

関連する問題