0

よろしくお願いします。

c#.net を使用しています。

Web ページに 2 つのビュー (1 つのマルチビューに含まれる) があり、どちらにもボタンが含まれています。

ビュー_1

リピーター/データソースとカスタムメイドの「編集」ボタン (返される各行の ID を保持します) が含まれています。

ビュー_2

「更新」フォームと「更新」ボタンが含まれています。ユーザーが更新ボタンを押すと、その特定の行のデータベース内の情報が更新されます。

私が信じている問題は、view_2 内の「更新」ボタンにあります

背後にあるコード (「更新」ボタン)、if ステートメントがあります。

        protected void Page_Load(object sender, EventArgs e)
    {
        updateSuccessFailed.Visible = false;

        if (!Page.IsPostBack)
        {
            _multiView1.ActiveViewIndex = 0;
        }
    }   

protected void update_Click(object sender, EventArgs e)

{

    var Id = Convert.ToInt32((ID.Value));

    notYetUpdated.Visible = true;
    updateSuccessFailed.Visible = false;

     tblV updateV = new tblV();

        updateV.vID = venueId;
        updateV.vame = updateName.ToString();
        updateV.vPostcode = updatePropPostcode.ToString();

        if (vRepos.Update(updateV))
        {
            notYetUpdated.Visible = false;
            updateSuccessFailed.Visible = true;
            updateMessage.Text = "Updated.";
        }
        else
        {
            notYetUpdated.Visible = false;
            updateSuccessFailed.Visible = true;
            updateMessage.Text = "An error has occurred, please try again.";
        }
}

_view2

<asp:View ID="_view2" runat="server">      
    <div style="text-align:center" runat="server" id="notYetUpdated">
      <table border="0" cellspacing="1">
        <tr>
          <td style="text-align:left;">Name</td>
          <td style="text-align:left;"><asp:TextBox ID="updateName" MaxLength="60" runat="server" /></td>
        </tr>
        <tr>
          <td style="text-align:left;">Postcode</td>
          <td style="text-align:left;"><asp:TextBox ID="updatePropPostcode" MaxLength="60" runat="server" /></td>         
        </tr>         
      </table><br />              

      <asp:Button ID="updateVCancel" Text="Cancel" runat="server" onclick="cancel_Click" CssClass="standardButton" />
      <asp:Button ID="updateVConfirm" Text="Update" runat="server" onclick="update_Click" CssClass="standardButton" />
      <asp:HiddenField ID="vUpdateID" runat="server" />     
    </div> 

    <div style="text-align:center" runat="server" id="updateSuccessFailed">
      <p><asp:Label ID="updateMessage" runat="server" /></p>
      <asp:Button ID="updateBack" Text="Back To Start" runat="server" onclick="backToStart_Click" CssClass="standardButton" /> 
    </div>

  </asp:View>

notYetUpdated / updateSuccessFailed は、異なる情報を保持する div です。

ユーザーが最初にレコードを「更新」すると、正しい div が表示されます。(notYetUpdated – フォーム情報を保持します / updateSuccessFailed – レコードが更新されたかどうかを示すメッセージを保持します)。ただし、view_2 に再度アクセスすると、update_Click イベントにアクセスし、updateSuccessFailed が表示されてはいけませんが、表示されます。

以下のコードを使用して、ビューステート内に保存されているすべての情報をクリアできると思いましたが、これは機能しません。

    ViewState.Clear();
    ClearChildViewState();

ありがとう

クレア :-)

4

2 に答える 2

0

これは私の側のエラーでした。私は自分のコードを適応させました。ここにあります:

var Id = Convert.ToInt32((ID.Value)); 

tblV updateV = new tblV();        
updateV.vID = venueId;        
updateV.vame = updateName.ToString();        
updateV.vPostcode = updatePropPostcode.ToString();  

notYetUpdated.Visible = false;    
updateSuccessFailed.Visible = true; 

if (vRepos.Update(updateV))        
{                   
updateMessage.Text = "Updated.";        
}        
else        
{     
updateMessage.Text = "An error has occurred, please try again.";        
}

これが他の人に役立つことを願っています。

于 2009-09-01T12:57:55.573 に答える