Vb.net 将UserControl动态添加到表单
我想在VB.Net中将usercontrol动态添加到表单中。我将从数据库中提取UserControl名称(字符串),如果该UserControl存在于项目中,我希望将其添加到表单中。 我知道如何以编程方式将usercontrols添加到表单中,但我不确定在使用字符串作为名称时如何添加usercontrolsVb.net 将UserControl动态添加到表单,vb.net,winforms,Vb.net,Winforms,我想在VB.Net中将usercontrol动态添加到表单中。我将从数据库中提取UserControl名称(字符串),如果该UserControl存在于项目中,我希望将其添加到表单中。 我知道如何以编程方式将usercontrols添加到表单中,但我不确定在使用字符串作为名称时如何添加usercontrols Dim userContName As UserControl = dtModules.Rows(k).Item("uc_Name") Panel1.Controls.Add(userCo
Dim userContName As UserControl = dtModules.Rows(k).Item("uc_Name")
Panel1.Controls.Add(userContName)
我试过这个办法
Public Sub LoadGroups()
dtModules = Tbl_GroupModulesTableAdapter1.GetDataBy_spGetModuleByGroup(grp.Name)
For k = 0 To dtModules.Rows.Count - 1
If grp.Name = dtModules.Rows(k).Item("Module_Group") Then
Dim fullyQualifiedClassName As String = dtModules.Rows(k).Item("Module_Name")
If fullyQualifiedClassName = Nothing Then
Else
Dim o = fetchInstance(fullyQualifiedClassName)
Dim b = CType(o, Control)
grp.Controls.Add(b)
End If
End If
Next
End Sub
Public Function fetchInstance(ByVal fullyQualifiedClassName As String) As Object
Dim nspc As String = fullyQualifiedClassName.Substring(0, fullyQualifiedClassName.LastIndexOf("."c))
Dim o As Object = Nothing
Try
For Each ay In Assembly.GetExecutingAssembly().GetReferencedAssemblies()
If (ay.Name = nspc) Then
o = Assembly.Load(ay).CreateInstance(fullyQualifiedClassName)
Exit For
End If
Next
Catch
End Try
Return o
End Function
好的,让它来处理这个
Dim ucName As String = Projectname.UserControlName
Dim newType As Type = Type.[GetType](ucName, True, True)
Dim o As Object = Activator.CreateInstance(newType)
Form.Controls.Add(o)
一旦我得到这个,它是相当简单的!谢谢你的反馈 可能重复的