ObjectDataSourceObjectEventHandler ObjectDataSourceObjectEventHandler ObjectDataSourceObjectEventHandler ObjectDataSourceObjectEventHandler Delegate

Definition

Stellt die Methode dar, die das ObjectCreating-Ereignis und das ObjectCreated-Ereignis des ObjectDataSource-Steuerelements behandelt.Represents the method that will handle the ObjectCreating and ObjectCreated events of the ObjectDataSource control.

public delegate void ObjectDataSourceObjectEventHandler(System::Object ^ sender, ObjectDataSourceEventArgs ^ e);
public delegate void ObjectDataSourceObjectEventHandler(object sender, ObjectDataSourceEventArgs e);
type ObjectDataSourceObjectEventHandler = delegate of obj * ObjectDataSourceEventArgs -> unit
Public Delegate Sub ObjectDataSourceObjectEventHandler(sender As Object, e As ObjectDataSourceEventArgs)

Parameter

sender
Object Object Object Object

Die Quelle des Ereignisses.The source of the event.

Vererbung
ObjectDataSourceObjectEventHandlerObjectDataSourceObjectEventHandlerObjectDataSourceObjectEventHandlerObjectDataSourceObjectEventHandler

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, wie ein ObjectDataSource -Steuerelement mit einem Geschäftsobjekt GridView und einem-Steuerelement verwendet wird, um Informationen abzurufen und anzuzeigen.The following code example demonstrates how to use an ObjectDataSource control with a business object and a GridView control to retrieve and display information. In diesem Beispiel, wie in vielen realen Szenarios, ist es möglicherweise nicht möglich oder angebracht, eine Standard Instanz des Geschäftsobjekts mit dem ObjectDataSource Steuerelement zu verwenden.In this example, as in many real-world scenarios, it might not be possible or appropriate to use a default instance of the business object with the ObjectDataSource control. In diesem Beispiel kann der ObjectDataSource Parameter lose Konstruktor nicht erfolgreich aufgerufen werden, da er eine Ausnahme auslöst.In this example, the ObjectDataSource cannot successfully call the parameterless constructor because it will throw an exception. In einigen Fällen kann der Parameter lose Konstruktor geschützt sein, und in anderen Fällen wird das Geschäftsobjekt möglicherweise nicht in einem gewünschten Zustand initialisiert.In some cases, the parameterless constructor might be protected, and in others it might not initialize the business object to a desired state. Der Grund hierfür ist, dass Sie das Geschäftsobjekt selbst instanziieren und die-Instanz auf ObjectInstance die-Eigenschaft ObjectDataSourceEventArgs des-Objekts festlegen können, das an den-Handler übermittelt wird.Whatever the reason, you can instantiate the business object yourself and set the instance to the ObjectInstance property of the ObjectDataSourceEventArgs object that is passed to the handler. Dies ist die Geschäftsobjekt Instanz, die ObjectDataSource von verwendet wird, um Ihre Arbeit auszuführen.This is the business object instance that the ObjectDataSource will use to perform its work.

<%@ 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 NorthwindLogicCreating(object sender, ObjectDataSourceEventArgs e)
{
    // Create an instance of the business object using a non-default constructor.
    EmployeeLogic eLogic = new EmployeeLogic("Not created by the default constructor!");
    
    // Set the ObjectInstance property so that the ObjectDataSource uses the created instance.
    e.ObjectInstance = eLogic;
}

</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">
        </asp:gridview>

        <asp:objectdatasource
          id="ObjectDataSource1"
          runat="server"
          selectmethod="GetAllEmployees"
          onobjectcreating="NorthwindLogicCreating"
          typename="Samples.AspNet.CS.EmployeeLogic" >
        </asp:objectdatasource>

    </form>
  </body>
</html>
<%@ Import namespace="Samples.AspNet.VB" %>
<%@ Page language="vb" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
Private Sub NorthwindLogicCreating(sender As Object, e As ObjectDataSourceEventArgs)

    ' Create an instance of the business object using a non-default constructor.
    Dim eLogic As EmployeeLogic = New EmployeeLogic("Not created by the default constructor!")
    
    ' Set the ObjectInstance property so that the ObjectDataSource uses the created instance.
    e.ObjectInstance = eLogic
    
End Sub ' NorthwindLogicCreating

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

        <asp:gridview
          id="GridView1"
          runat="server"
          datasourceid="ObjectDataSource1">
        </asp:gridview>

        <asp:objectdatasource
          id="ObjectDataSource1"
          runat="server"
          selectmethod="GetAllEmployees"
          onobjectcreating="NorthwindLogicCreating"
          typename="Samples.AspNet.VB.EmployeeLogic" >
        </asp:objectdatasource>

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

Im folgenden Codebeispiel wird das grundlegende Geschäftsobjekt veranschaulicht, das im vorherigen Beispiel verwendet wurde.The following code example demonstrates the example basic business object used in the preceding example.

namespace Samples.AspNet.CS {

using System;
using System.Collections;
using System.Web.UI;
using System.Web.UI.WebControls;

  public class EmployeeLogic {

    public EmployeeLogic() {  
        throw new NotSupportedException("Initialize data.");
    }
    
    public EmployeeLogic(string data) {
        _data = data;
    }

    private string _data;
    
    // Returns a collection of NorthwindEmployee objects.
    public ICollection GetAllEmployees () {
      ArrayList al = new ArrayList();      
      al.Add(_data);        
      return al;
    }
    
  }

}
Imports System.Collections
Imports System.Web.UI
Imports System.Web.UI.WebControls

Namespace Samples.AspNet.VB
  Public Class EmployeeLogic
    
    
    Public Sub New() 
        Throw New NotSupportedException("Initialize data.")
    
    End Sub
    
    
    Public Sub New(ByVal data As String) 
        _data = data
    
    End Sub
    
    Private _data As String
    
    
    ' Returns a collection of NorthwindEmployee objects.
    Public Function GetAllEmployees() As ICollection 
        Dim al As New ArrayList()
        al.Add(_data)
        Return al
    
    End Function 'GetAllEmployees
  End Class
End Namespace ' Samples.AspNet.VB

Hinweise

Beim Erstellen eines ObjectDataSourceObjectEventHandler-Delegaten geben Sie die Methode für die Ereignisbehandlung an.When you create an ObjectDataSourceObjectEventHandler delegate, you identify the method that will handle the event. Um dem Ereignishandler das Ereignis zuzuordnen, fügen Sie dem Ereignis eine Instanz des Delegaten hinzu.To associate the event with your event handler, add an instance of the delegate to the event. Der Ereignishandler wird bei jedem Eintreten des Ereignisses aufgerufen, sofern der Delegat nicht entfernt wird.The event handler is called whenever the event occurs, unless you remove the delegate. Weitere Informationen zum Behandeln von Ereignissen finden Sie unter behandeln und Auslösen von Ereignissen.For more information about how to handle events, see Handling and Raising Events.

Erweiterungsmethoden

GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate)

Ruft ein Objekt ab, das die Methode darstellt, die vom angegebenen Delegaten dargestellt wird.Gets an object that represents the method represented by the specified delegate.

Gilt für:

Siehe auch