ObjectDataSourceEventArgs ObjectDataSourceEventArgs ObjectDataSourceEventArgs ObjectDataSourceEventArgs Class

定義

ObjectCreating コントロールの ObjectCreated イベントおよび ObjectDataSource イベントのデータを提供します。Provides data for the ObjectCreating and ObjectCreated events of the ObjectDataSource control.

public ref class ObjectDataSourceEventArgs : EventArgs
public class ObjectDataSourceEventArgs : EventArgs
type ObjectDataSourceEventArgs = class
    inherit EventArgs
Public Class ObjectDataSourceEventArgs
Inherits EventArgs
継承
ObjectDataSourceEventArgsObjectDataSourceEventArgsObjectDataSourceEventArgsObjectDataSourceEventArgs

このセクションには、2 つのコード例が含まれています。This section contains two code examples. 最初のコード例を使用する方法を示します、ObjectDataSourceビジネス オブジェクトを持つコントロールとGridViewコントロールを取得し、情報を表示します。The first code example demonstrates how to use an ObjectDataSource control with a business object and a GridView control to retrieve and display information. 2 番目のコード例では、最初のコード例では使用する基本的なビジネス オブジェクトの例を提供します。The second code example provides the example basic business object that the first code example uses.

次のコード例は、使用する方法を示します、ObjectDataSourceビジネス オブジェクトを持つコントロールとGridViewコントロールを取得し、情報を表示します。The following code example demonstrates how to use an ObjectDataSource control with a business object and a GridView control to retrieve and display information. 多くの現実のシナリオと同様に、この例では、できない可能性があります可能性も適切に使用するビジネス オブジェクトの既定のインスタンスを使用する、ObjectDataSourceコントロール。In this example, as in many real-world scenarios, it might not be possible nor appropriate to use a default instance of the business object with the ObjectDataSource control. この例で、ObjectDataSourceは例外をスローするために、既定のコンス トラクターを正常に呼び出すことはできません。In this example, the ObjectDataSource cannot successfully call the default constructor because it will throw an exception. 場合によっては、既定のコンス トラクターは、保護し、他のユーザーで、目的の状態にビジネス オブジェクトを初期化、可能性がありますできません。In some cases, the default constructor might be protected and in others it might not initialize the business object to a desired state. 理由にかかわらず、自分でビジネス オブジェクトのインスタンスを作成し、インスタンスを設定、ObjectInstanceのプロパティ、ObjectDataSourceEventArgsハンドラーに渡されるオブジェクト。Whatever the reason, you can create an instance of the business object yourself and set the instance to the ObjectInstance property of the ObjectDataSourceEventArgs object that is passed to the handler. これは、ビジネス オブジェクトをインスタンス化する、ObjectDataSourceその作業の実行に使用します。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>

次のコード例では、前のコード例で使用する基本的なビジネス オブジェクトの例を示します。The following code example demonstrates the example basic business object that the preceding code example uses.

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
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 'New
    
    
    Public Sub New(ByVal data As String) 
        _data = data
    
    End Sub 'New
    
    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 'EmployeeLogic 
End Namespace ' Samples.AspNet.VB

注釈

ObjectDataSourceEventArgsクラスが使用されて、OnObjectCreatingOnObjectCreatedメソッドを使用している任意のデータ操作の前にビジネス オブジェクトのインスタンスへのアクセスを提供する、ObjectDataSourceコントロール、およびビジネス オブジェクトを実行します。The ObjectDataSourceEventArgs class is used in the OnObjectCreating and OnObjectCreated methods to provide access to the business object instance before any data operations that are using the ObjectDataSource control and business object are performed. ビジネス オブジェクトが設定され、アクセスを使用して、ObjectInstanceプロパティ。The business object is set and accessed using the ObjectInstance property. 処理するイベント ハンドラー デリゲートを追加することで、ObjectCreatingイベントの代わりにカスタム コードでビジネス オブジェクトのインスタンスを作成することができます、ObjectDataSourceをインスタンス化を実行します。By adding an event handler delegate to handle the ObjectCreating event, you can create an instance of the business object in custom code instead of the ObjectDataSource performing the instantiation. これは、既定以外のインスタンスまたはビジネス オブジェクトのインスタンスを作成する既定以外のコンス トラクターを呼び出すにする場合に便利です。ObjectDataSource常に連携するビジネス オブジェクトのインスタンスを作成する既定のコンス トラクターを呼び出します。This is useful when you want a non-default instance of your business object or to call a non-default constructor to create the instance; the ObjectDataSource always calls the default constructor to create an instance of the business object it works with. 処理するイベント ハンドラー デリゲートを追加することも、ObjectCreated公開される追加の初期化または作業を実行するビジネス オブジェクトのメンバーのイベントで、いずれかにパブリックにアクセスすることができます。You can also add an event handler delegate to handle the ObjectCreated event, which enables you to access any publicly exposed members of the business object to perform any additional initialization or work.

OnObjectCreatingOnObjectCreatedメソッドを呼び出さない、ObjectDataSourceデータ操作を実行するビジネス オブジェクト メソッドの場合、制御staticします。The OnObjectCreating and OnObjectCreated methods are not called by the ObjectDataSource control, if the business object method that performs the data operations is static.

ObjectDataSourceコントロールは、ライフ サイクルのさまざまな時点で、基になるビジネス オブジェクトを使用する処理できる多くのイベントを公開します。The ObjectDataSource control exposes many events that you can handle to work with the underlying business object at various times in its lifecycle. 次の表は、イベントと関連付けられているEventArgsクラスとイベント ハンドラー デリゲート。The following table lists the events and the associated EventArgs classes and event handler delegates.

eventEvent EventArgsEventArgs EventHandlerEventHandler
ObjectCreatingObjectCreating.

ビジネス オブジェクトのインスタンスが作成される直前に発生します。Occurs immediately before the instance of the business object is created.
ObjectDataSourceEventArgs ObjectDataSourceObjectEventHandler
ObjectCreatedObjectCreated.

ビジネス オブジェクトのインスタンスが作成された直後後に発生します。Occurs immediately after the instance of the business object is created.
ObjectDataSourceEventArgs ObjectDataSourceObjectEventHandler
SelectingSelecting.

データを取得する前に発生します。Occurs before the data is retrieved.
ObjectDataSourceSelectingEventArgs ObjectDataSourceSelectingEventHandler
InsertingUpdating、および DeletingInserting, Updating, and Deleting.

挿入、更新、または削除操作を実行する前に発生します。Occur before an insert, update, or delete operation is performed.
ObjectDataSourceMethodEventArgs ObjectDataSourceMethodEventHandler
SelectedSelected.

データが取得された後に発生します。Occurs after the data is retrieved.
ObjectDataSourceStatusEventArgs ObjectDataSourceStatusEventHandler
Inserted, Updated, Deleted.Inserted, Updated, Deleted.

Insert、update、または削除操作が完了した後に発生します。Occur after the insert, update, or delete operation is completed.
ObjectDataSourceStatusEventArgs ObjectDataSourceStatusEventHandler
ObjectDisposingObjectDisposing.

ビジネス オブジェクトが破棄される前に発生します。Occurs before a business object is destroyed.
ObjectDataSourceDisposingEventArgs ObjectDataSourceDisposingEventHandler

コンストラクター

ObjectDataSourceEventArgs(Object) ObjectDataSourceEventArgs(Object) ObjectDataSourceEventArgs(Object) ObjectDataSourceEventArgs(Object)

指定されたオブジェクトを使用して、ObjectDataSourceEventArgs クラスの新しいインスタンスを初期化します。Initializes a new instance of the ObjectDataSourceEventArgs class using the specified object.

プロパティ

ObjectInstance ObjectInstance ObjectInstance ObjectInstance

ObjectDataSource コントロールがデータ操作を実行するビジネス オブジェクトを表すオブジェクトを取得または設定します。Gets or sets an object that represents the business object with which the ObjectDataSource control performs data operations.

メソッド

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

指定したオブジェクトが、現在のオブジェクトと等しいかどうかを判断します。Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(Inherited from Object)
GetType() GetType() GetType() GetType()

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(Inherited from Object)
ToString() ToString() ToString() ToString()

現在のオブジェクトを表す文字列を返します。Returns a string that represents the current object.

(Inherited from Object)

適用対象

こちらもご覧ください