函数返回参数中指定类型的对象

End*_*ono 5 vb.net

如何创建一个返回特定类型对象的函数,该函数的用户在参数中指定(使用vb.net 2010)?

Private Function TryThis(ByVal t As Type) As Object
    Dim n = New t
    Return n
End Function
Run Code Online (Sandbox Code Playgroud)

上面的代码不起作用,但也许它可以解释我想要实现的目标.

使用此功能,我想从数据表中保存数据传输对象.客户端只需调用此函数,指定客户端需要哪个DTO,此函数将只创建该DTO并使用反射填充属性GetType.GetProperties().

Chr*_*aas 4

这是一个使用泛型的非常基本的示例。该方法GetPropFromDatabase仅使用 aSelect Case但显然您会进行真正的数据库查找调用。

Option Explicit On
Option Strict On

Public Class Form1
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        Dim X = CreateObject(Of TestClass)()

        Trace.WriteLine(X.PropertyA)
        Trace.WriteLine(X.PropertyB)

        Me.Close()
    End Sub

    ''//Of T as New means that the object must have a constructor
    Private Function CreateObject(Of T As New)() As T
        ''//Create our object
        Dim O As New T
        ''//Get the type properties
        Dim Props = GetType(T).GetProperties()
        ''//Loop through each property
        For Each P In Props
            ''//Set the value of our return type by property name
            P.SetValue(O, GetPropFromDatabase(P.Name), Nothing)
        Next
        ''//Return our object
        Return O
    End Function
    ''//This function would obviously do a lot more
    Private Shared Function GetPropFromDatabase(ByVal name As String) As String
        Select Case name
            Case "PropertyA"
                Return "Value1"
            Case "PropertyB"
                Return "Value2"
        End Select

        Throw New ApplicationException(String.Format("Unknown database column : {0}", name))
    End Function
End Class
Public Class TestClass
    Public Property PropertyA As String
    Public Property PropertyB As String
End Class
Run Code Online (Sandbox Code Playgroud)

编辑

您可能需要根据对象的设置方式来使用BindingFlagson 。GetProperties()

编辑2

您可能还想研究使用自定义属性。例如,如果数据库中有一个名为[First Name]that 的列,由于空间的原因,显然不能作为对象属性存在。使用自定义属性,您可以将某些属性标记为要忽略或以特殊方式进行解析。下面的代码显示了上述代码的扩展版本。

Option Explicit On
Option Strict On

Public Class Form1
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        Dim X = CreateObject(Of TestClass)()

        Trace.WriteLine(X.PropertyA)
        Trace.WriteLine(X.PropertyB)
        Trace.WriteLine(X.FirstName)

        Me.Close()
    End Sub

    ''//Of T as New means that the object must have a constructor
    Private Function CreateObject(Of T As New)() As T
        ''//Create our object
        Dim O As New T
        ''//Get the type properties
        Dim Props = GetType(T).GetProperties()

        ''//Will hold the name of the database column to get the value of
        Dim PropName As String
        ''//Will hold our collection of attributes on the property
        Dim CustomAttributes() As Object
        ''//Loop through each property
        For Each P In Props
            ''//Default the value to the property name
            PropName = P.Name
            ''//Try to get any custom attributes for the property
            CustomAttributes = P.GetCustomAttributes(True)
            ''//See if we have anything to work with
            If (CustomAttributes IsNot Nothing) AndAlso (CustomAttributes.Count > 0) Then
                ''//Loop through each attribute
                For Each A In CustomAttributes
                    ''//If the attribute is our custom one defined below
                    If TypeOf A Is ColumnNameInDatabase Then
                        ''//Use the manually set column name instead
                        PropName = DirectCast(A, ColumnNameInDatabase).ColumnNameInDatabase
                        ''//No reason to loop through any more attributes so exit
                        Exit For
                    End If
                Next
            End If
            ''//Set the value of our return type by property name
            P.SetValue(O, GetPropFromDatabase(PropName), Nothing)
        Next
        ''//Return our object
        Return O
    End Function
    ''//This function would obviously do a lot more
    Private Shared Function GetPropFromDatabase(ByVal name As String) As String
        Select Case name
            Case "PropertyA"
                Return "Value1"
            Case "PropertyB"
                Return "Value2"
            Case "First Name"
                Return "Bob Dole"
        End Select

        Throw New ApplicationException(String.Format("Unknown database column : {0}", name))
    End Function
End Class
Public Class TestClass
    Public Property PropertyA As String
    Public Property PropertyB As String
    <ColumnNameInDatabase("First Name")> Public Property FirstName As String
End Class
Public Class ColumnNameInDatabase
    Inherits Attribute
    Private _ColumnNameInDatabase As String
    Public ReadOnly Property ColumnNameInDatabase As String
        Get
            Return Me._ColumnNameInDatabase
        End Get
    End Property
    Public Sub New(ByVal columnNameInDatabase As String)
        Me._ColumnNameInDatabase = columnNameInDatabase
    End Sub
End Class
Run Code Online (Sandbox Code Playgroud)