水如烟

秋里生活,恬淡宁静。那如洗碧空,那伏黄草地,风凉夜寂,心儿涌动,情绪萦绕。可以凭窗,可以临江,可以坐,可以仰卧,可以独处,可以相依。倚明月,抚清辉,人生多少情怀,尽在秋里?

原创 按控件实例名称及其属性名称实现动态赋值收藏

新一篇: Sender代表什么 | 旧一篇: 使BLOG上的代码保留NET的文本样式

    '按控件实例名称及其属性名称实现动态赋值

    '入口参数:ClassInstance  控件所在的类实例

    '         ControlName 控件实例名称,区分大小写

    '         PropertyName 要设值的控件属性名称,区分大小写(其实这里可以不必区分大小写的,只是为了养成习惯,我这样要求自己的)

    '         Value 新值,类型是一个Object,这倒是要注意的

    '出口参数: True则重设成功,False不成功

    '需要 Imports System.ReflectionImports System.ComponentModel

    Public Function SetValueControlProperty(ByVal ClassInstance As Object, ByVal ControlName As String, ByVal PropertyName As String, ByVal Value As Object) As Boolean

        Dim Result As Boolean = False '返回值。虽然默认是Flase,但我还是喜欢这样设它,主要是看着明了

        '下面我不注释了

        Dim myType As Type = ClassInstance.GetType

        Dim myFieldInfo As FieldInfo = myType.GetField("_" & ControlName, BindingFlags.NonPublic Or _

                                     BindingFlags.Instance Or BindingFlags.Public Or BindingFlags.Instance) '"_"这个是特要紧的

 

        If Not myFieldInfo Is Nothing Then

            Dim properties As PropertyDescriptorCollection = TypeDescriptor.GetProperties(myType)

            Dim myProperty As PropertyDescriptor = properties.Find(PropertyName, False)  '这里设为True就不用区分大小写了

 

            If Not myProperty Is Nothing Then

                Dim ctr As Object

                ctr = myFieldInfo.GetValue(ClassInstance) '取得控件实例

                Try

                    myProperty.SetValue(ctr, Value)

                    Result = True

                Catch ex As Exception

                    MsgBox(ex.Message)

                End Try

            End If

        End If

 

        Return Result

    End Function

 

    '测试

    Private Sub Test()

        SetValueControlProperty(Me, "Button1", "Text", "Hello")

        SetValueControlProperty(Me, "Button2", "Visible", False)

        Dim frm As New Form2

        SetValueControlProperty(frm, "MyTextBox", "Text", "应该还行吧?")

        frm.Show()

    End Sub

发表于 @ 2004年08月01日 01:07:00|评论(loading...)|编辑

新一篇: Sender代表什么 | 旧一篇: 使BLOG上的代码保留NET的文本样式

评论

#lzmtw 发表于2004-08-01 11:58:00  IP: 218.15.224.*
我想让函数返回控件实例本身会更好些
Dim Result As Objct
......
Dim ctr As Object
ctr = myFieldInfo.GetValue(ClassInstance) '取得控件实例
Try
myProperty.SetValue(ctr, Value)
Result = ctr
Catch ex As Exception
MsgBox(ex.Message)
End Try
#巴山夜雨 发表于2004-08-23 09:52:00  IP: 202.96.176.*
SetValueControlProperty(Me, "Me", "Text", "ddd")
为什么不行呢
#wcbao 发表于2007-03-26 18:22:53  IP: 222.222.141.*
以下两条语句:
SetValueControlProperty(Me, "Button1", "Text", "Hello")
SetValueControlProperty(frm, "MyTextBox", "Text", "应该还行吧?")

在vs.net 2005 中出现“对象和目标值不匹配"的异常,楼主能不能帮忙解释一下
#wcbao 发表于2007-03-27 11:47:14  IP: 222.222.141.*
在vb.net 2005 中
由于原代码出现“对象与目标类型不匹配”异常
本人稍微修改了一下代码即可正常运行了:
Public Function SetValueControlProperty(ByVal ClassInstance As Object, ByVal ControlName As String, ByVal PropertyName As String, ByVal Value As Object) As Boolean

Dim Result As Boolean = False '返回值。虽然默认是Flase,但我还是喜欢这样设它,主要是看着明了

'下面我不注释了

Dim myType As Type = ClassInstance.GetType

Dim myFieldInfo As FieldInfo = myType.GetField("_" & ControlName, BindingFlags.NonPublic Or BindingFlags.Instance Or BindingFlags.Public Or BindingFlags.Instance) '加"_"这个是特要紧的
Dim ctr As Object
ctr = myFieldInfo.GetValue(ClassInstance) '取得控件实例
If Not myFieldInfo Is Nothing Then
Dim myProperty As PropertyInfo = ctr.GetType().GetProperty(PropertyName, BindingFlags.NonPublic Or BindingFlags.Public Or BindingFlags.Instance)
If Not myProperty Is Nothing Then
Try
myProperty.SetValue(ctr, Value, Nothing)
Result = True
Catch ex As Exception
MsgBox(ex.Message)
End Try
End If
End If
Return Result
End Function
#wing013 发表于2007-11-13 16:21:05  IP: 219.130.69.*
看了,但還要再認真看看才懂.
mark
发表评论  


登录
Csdn Blog version 3.1a
Copyright © 水如烟