ObjectDataSourceView.Deleting Olay

Tanım

İşlemden Delete önce gerçekleşir.

C#
public event System.Web.UI.WebControls.ObjectDataSourceMethodEventHandler Deleting;

Olay Türü

Örnekler

Aşağıdaki kod örneği, verileri silmek için bir ObjectDataSource iş nesnesi ve denetim ile bir GridView denetimin nasıl kullanılacağını gösterir. başlangıçta GridView , nesnesinden verileri almak için özelliği tarafından SelectMethod belirtilen yöntemini kullanarak tüm çalışanlardan oluşan EmployeeLogic bir küme görüntüler. AutoGenerateDeleteButton özelliği olarak trueayarlandığındanGridView, denetim otomatik olarak bir Sil düğmesi görüntüler.

Sil düğmesine tıklarsanız, Delete işlem özelliği tarafından DeleteMethod belirtilen yöntemi ve koleksiyonda DeleteParameters belirtilen tüm parametreler kullanılarak gerçekleştirilir. Bu kod örneğinde bazı ön işleme ve işlem sonrası adımları da gerçekleştirilir. TemsilciNorthwindEmployeeDeleting, işlem gerçekleştirilmeden önce Delete olayı işlemek Deleting için çağrılır ve NorthwindEmployeeDeleted bir özel durum işleme gerçekleştirmek üzere işlem tamamlandıktan sonra Delete olayı işlemek Deleted için temsilci çağrılır. Bu örnekte, bir NorthwindDataException oluşturulursa, bu temsilci tarafından işlenir.

Bu kod örneğinin EmployeeLogic kullandığı orta katman iş nesnesinin uygulamasını incelemek için bkz ObjectDataSourceStatusEventArgs. .

ASP.NET (C#)
<%@ Register TagPrefix="aspSample" Namespace="Samples.AspNet.CS" Assembly="Samples.AspNet.CS" %>
<%@ Import namespace="Samples.AspNet.CS" %>
<%@ Page language="c#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
private void NorthwindEmployeeDeleting(object source, ObjectDataSourceMethodEventArgs e)
{
  // The GridView passes the ID of the employee
  // to be deleted. However, the buisiness object, EmployeeLogic,
  // requires a NorthwindEmployee parameter, named "ne". Create
  // it now and add it to the parameters collection.
  IDictionary paramsFromPage = e.InputParameters;
  if (paramsFromPage["EmpID"] != null) {
    NorthwindEmployee ne
      = new NorthwindEmployee( Int32.Parse(paramsFromPage["EmpID"].ToString()));
    // Remove the old EmpID parameter.
    paramsFromPage.Clear();
    paramsFromPage.Add("ne", ne);
  }
}

private void NorthwindEmployeeDeleted(object source, ObjectDataSourceStatusEventArgs e)
{
  // Handle the Exception if it is a NorthwindDataException
  if (e.Exception != null)
  {

    // Handle the specific exception type. The ObjectDataSource wraps
    // any Exceptions in a TargetInvokationException wrapper, so
    // check the InnerException property for expected Exception types.
    if (e.Exception.InnerException is NorthwindDataException)
    {
      Label1.Text = e.Exception.InnerException.Message;
      // Because the exception is handled, there is
      // no reason to throw it.
      e.ExceptionHandled = true;
    }
  }
}

</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
  <head>
    <title>ObjectDataSource - C# Example</title>
  </head>
  <body>
    <form id="Form1" method="post" runat="server">

        <asp:gridview
          id="GridView1"
          runat="server"
          datasourceid="ObjectDataSource1"
          autogeneratedeletebutton="true"
          autogeneratecolumns="false"
          datakeynames="EmpID">
          <columns>
            <asp:boundfield headertext="EmpID" datafield="EmpID" />
            <asp:boundfield headertext="First Name" datafield="FirstName" />
            <asp:boundfield headertext="Last Name" datafield="LastName" />
          </columns>
        </asp:gridview>

        <asp:objectdatasource
          id="ObjectDataSource1"
          runat="server"
          selectmethod="GetAllEmployees"
          deletemethod="DeleteEmployee"
          ondeleting="NorthwindEmployeeDeleting"
          ondeleted="NorthwindEmployeeDeleted"
          typename="Samples.AspNet.CS.EmployeeLogic">
          <deleteparameters>
            <asp:parameter name="EmpID" type="Int32" />
          </deleteparameters>
        </asp:objectdatasource>

        <asp:label id="Label1" runat="server" />

    </form>
  </body>
</html>

Açıklamalar

Deleting Denetim işlemi gerçekleştirmeden önce ObjectDataSource uygulamanıza özgü ek başlatma işlemleri gerçekleştirmek, parametrelerin değerlerini doğrulamak veya parametre değerlerini değiştirmek için olayı işleyinDelete. Parametreler, nesnesi tarafından kullanıma sunulan ObjectDataSourceMethodEventArgs özelliği tarafından InputParameters erişilen bir IDictionary koleksiyon olarak kullanılabilir.

Olayları işleme hakkında daha fazla bilgi için bkz. Olayları İşleme ve Oluşturma.

Şunlara uygulanır

Ürün Sürümler
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

Ayrıca bkz.