1

編集と削除を許可するリストビューがあります。リストビューのリンクボタンをクリックすると、page_load が起動され、次に OnItemCommand が起動されます。コマンドの最後に、リストビューを更新しない DataBind を追加しましたが、エントリを削除しました。DataBind を (...aspx?ID=...) で同じページにリダイレクトするように変更すると、新しいページが返されます。しかし、デバッグ モードでは、page_load と Databind を介して実行されることがわかりました。

<asp:UpdatePanel ID="UpdateOptions" runat="server" >
    <ContentTemplate>
        <asp:Panel ID="OPanel" runat="server" width="350px">
            <asp:ListView runat="server" ID="lvPollOptions" DataKeyNames="POptionID" OnItemCommand="lvPollOptions_ItemCommand" OnDataBound="lvPollOptions_ItemDataBound" >
                <LayoutTemplate>
                    <table cellpadding="0" cellspacing="0" border="0" width="300px">
                        <tr class="AdminListHeader">
                        </tr>

                        <tr id="itemPlaceholder" runat="server">
                        </tr>

                    </table>
                </LayoutTemplate>

                <ItemTemplate>
                    <tr>
                        <td>
                            <%#Eval("OptionText")%>
                        </td>

                        <td>
                            <%#Eval("Votes")%>
                        </td>

                        <td align="center">
                            <asp:ImageButton runat="server" ID="ibtnEditOption" CommandArgument='<%# Eval("POptionID").ToString() %>' CommandName="Edit" ImageUrl="~/images/buttons/EditPencil.gif" AlternateText="Edit" CssClass="AdminImg" />
                        </td>

                        <td>
                            <asp:ImageButton runat="server" ID="ibtnDeleteOption" CommandArgument='<%# Eval("POptionID").ToString() %>' CommandName="Delete" ImageUrl="~/images/buttons/delete.gif" AlternateText="Delete" CssClass="AdminImg" OnClientClick="return confirm('Warning: This will delete the Poll Option from the database.');" />
                        </td>
                    </tr>
                </ItemTemplate>

            </asp:ListView>

            <asp:Label ID="lblNoOption" runat="server" Text="No Options Added"></asp:Label>

            <table width="345px">
                <tr>
                    <td width="100px">
                        Option:
                    </td>

                    <td>
                        <asp:TextBox ID="txtOption" runat="server" width="200px"></asp:TextBox>
                    </td>
                </tr>
            </table>
        </asp:Panel>
    </ContentTemplate>
</asp:UpdatePanel>

コードビハインド

protected void PollBindData()
{
    SqlConnection connOption = new SqlConnection(connStr);
    connOption.Open();
    SqlDataAdapter da = new SqlDataAdapter("SELECT POptionID, OptionText, Votes FROM [PollOptions] Where PollID = '" + PID + "'", connOption);
    DataSet dsSel = new DataSet();
    da.Fill(dsSel);
    lvPollOptions.DataSource = dsSel;
    lvPollOptions.DataBind();
    connOption.Close();
}

protected void Page_Load(object sender, EventArgs e)
{
    string PID = Request.QueryString["ID"];

    if (!IsPostBack)
    {
        if (PID == null)
        {

        }
        else if (PID != null)
        {
            PollBindData();
        }
    }
}

protected void lvPollOptions_ItemDataBound(object sender, ListViewItemEventArgs e)
{
    string PID = Request.QueryString["ID"];

    SqlConnection connOption = new SqlConnection(connStr);
    connOption.Open();
    SqlDataAdapter da = new SqlDataAdapter("SELECT POptionID, OptionText, Votes      FROM [PollOptions] Where PollID = '" + PID + "'", connOption);
    DataSet dsSel = new DataSet();
    da.Fill(dsSel);
    lvPollOptions.DataSource = dsSel;
    lvPollOptions.DataBind();
    connOption.Close();
}

protected void lvPollOptions_ItemCommand(object sender, ListViewCommandEventArgs e)
{
    if (e.CommandName == "Delete")
    {
        string selectedID = e.CommandArgument.ToString();
        SqlConnection connDeleteOption = new SqlConnection(connStr);
        connDeleteOption.Open();
        SqlCommand cmdDeleteOption = new SqlCommand("DELETE FROM [PollOptions] WHERE POptionID = '" + selectedID + "'", connDeleteOption);
        cmdDeleteOption.ExecuteNonQuery();
        connDeleteOption.Close();

        PollBindData();
        //Response.Redirect("aAddEditPoll.aspx?ID=" + selectedID);
    }

    if (e.CommandName == "Edit")
    {
        string EditID = e.CommandArgument.ToString();
        SqlConnection conn = new SqlConnection(connStr);
        conn.Open();
        SqlCommand cmdView = new SqlCommand("SELECT OptionText From [PollOptions] Where POptionID = '" + EditID + "'", conn);
        SqlDataReader dr1 = cmdView.ExecuteReader();

        if (dr1.Read())
        {
            txtOption.Text = dr1["OptionText"].ToString();
        }

        Session["OptionID"] = txtOption.Text;
        dr1.Close();
        conn.Close();

        lbOInsert.Visible = false;
        lbOUpdate.Visible = true;

        PollBindData();
        //Response.Redirect("aAddEditPoll.aspx?ID=" + EditID);
    }
}
4

1 に答える 1

0

始める前に - あなたのコードはSql インジェクションの影響を受けやすいため、セキュリティ リスクがあります。クエリをパラメータ化してください...

さて、あなたの質問はあまり明確ではありませんが、私の理解が正しければ、オブジェクトを削除した後、ポストバック後にリストビューが更新されない (たとえば、削除されたアイテムがまだ表示されている) と言っています。UpdatePanel で実行しているため、DataBind の後にパネルを更新してください...

PoolBindDataこのように更新

protected void PollBindData()
{
    SqlConnection connOption = new SqlConnection(connStr);
    connOption.Open();

    // POTENTIAL SECURITY RISK - MAKE SURE YOU PARAMETRIZE THE QUERY!!
    SqlDataAdapter da = new SqlDataAdapter("SELECT POptionID, OptionText, Votes FROM [PollOptions] Where PollID = '" + PID + "'", connOption);

    DataTable dsSel = new DataTable();
    da.Fill(dsSel);
    lvPollOptions.DataSource = dsSel;
    lvPollOptions.DataBind();
    connOption.Close();

    // Update panel
    UpdateOptions.Update();
}
于 2012-12-19T15:03:24.057 に答える