0

投稿したリピーターコントロールでユーザーの画像を表示する必要があるFacebookウォールのようなシナリオがあります。

試してみましたが、機能しmyrepeater_ItemCommand1ませmyrepeater_ItemDataBoundん。

コードビハインド

protected void myrepeater_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
    try
    {
        LinkButton lblPostedBy = (LinkButton)e.Item.FindControl("lblPostedBy");
        con.Open();
        cmd.CommandText = "select image from " + lblPostedBy.Text + " where id=1";
        cmd.Connection = con;
        string imageurl = (string)cmd.ExecuteScalar();
        con.Close();
        Image Image1 = (Image)e.Item.FindControl("Image1");
        Image1.ImageUrl = imageurl;
    }

    catch (Exception a)
    {
        lblMsg.Text = a.Message;
        msgbox.Visible = true;
    }
}

myrepeater_ItemCommand1リピーター内のボタンをクリックすると、同じように機能します。

またはRepeater controlの時点でどのイベントが発生したかを知りたかったのです。Page_LoadPage_Init

または、私の仕事を達成するための他の方法を教えてください。

ところで、私のプロジェクトはC# ASP.NET 4.

4

1 に答える 1

1

投稿が保存されたら、リピーターを再バインドする必要があります。リピーターを再バインドすると、更新が表示されます。

//update some stuff in the database

Repeater1.DataSource = RepeaterDataSource();
Repeater1.DataBind();

編集

<asp:Repeater ID="Repeater1" runat="server" ...>
    <ItemTemplate>
        <asp:Image ID="imgProfilePic" runat="server" ImageUrl='<%#Eval("ProfileImageUrl")%>' ... />
        <%#Eval("PostMessage")%>
    </ItemTemplate>
</asp:Repeater>

そしてコードビハインドで:

protected void BindDataToRepeater()
{
    Repeater1.DataSource = GetUserPosts();
    Repeater1.DataBind();
}

更新後:

protected void Button1_Click(object sender, EventArgs e)
{
    //save post to database
    SavePost();

    //rebind the repeater to display the post that was just added
    BindDataToRepeater();
}
于 2011-09-28T13:47:44.373 に答える