我真的很纠结于这里的一些事情。我有一个类模块,我们称它为FormMan,它有一堆与我的项目中的大量用户表单相关的方法。一种特殊的方法是从许多不同的地方调用,而且非常简单-它只需将用户定义的控件数量添加到窗体中,并扩展窗体高度以适应这些新控件。
用户传递控件的数量和用户表单。
oF.AddControlsToForm iNumberOfControls,frmTest在FormMan类模块中:
Public Sub Addcontrols(iNum as integer, oForm as userform)
//stuff happens here, oForm is used extensively
oForm.Height = i //object does not support this property or method
frmTest.Height = i //works
oForm.Show //object does not...
frmTest.show //works
end sub在“局部变量”窗口中,oForm没有height属性,因此足够公平。但是oForm被定义为frmTest。例如,我可以说oForm.BackColor = vbred,我可以设置ctl = oform.TextBox1
这是一个泛型过程,可以向任何表单添加一组控件。在将表单分配给oForm之前,我已经尝试过加载和显示表单。
为什么高度和显示属性和方法是用户表单而不是对象声明为用户表单?我做错了什么?
真的很感谢你的帮助。
发布于 2009-02-12 21:17:16
这里的问题是UserForm和frmTest对象不是同一类型。实际上,frmTest是UserForm的一个子类型,它通过添加Height属性和其他成员来扩展它。
您可能不得不将函数参数声明为Object。
Public Sub Addcontrols(iNum as integer, oForm as Object)这应该可以如您所愿地工作,尽管不幸的是,您将牺牲类型安全性。大多数面向对象的概念在VBA的上下文中往往会分崩离析。
发布于 2009-02-12 21:20:51
关于VBA,首先要记住的是它是准面向对象的,而不是全面向对象的。我在这个问题上遇到了很多奇怪的问题,所以我现在倾向于避免完全依赖VBA的一致性。
话虽如此,你可以试试这个:
Dim fname = oForm.Name (or whatever the property is for this subobject)
With VBA.UserForms.Add(fname)
.Height = x
.Show
End With这不是很奇特吗?!?!我没有现成的代码示例等待,所以我不能保证成功,但感觉这是正确的方法。
https://stackoverflow.com/questions/543243
复制相似问题