Excel/VBA 在我工作的组织中被广泛使用。为了让事情变得更容易,我正在研究一些在 .NET/VS2010 中广泛使用的 COM 类,以便在 VBA 中使用。
但是,我似乎无法实现支持每个循环的 COM 对象。如何实现这种行为?
要指定一点:
在许多情况下,我会创建一些类(我们称之为 SomeClass)和一个随附的专用集合类(我们称之为 SomeClassCollection)。在纯 .NET 中,这通常不是必需的,因为我可以简单地为通用容器创建必要的专用扩展(例如 List(Of SomeClass))。但是,在 VBA/COM 中,我需要为大多数自定义类创建一个单独的专用集合类。
对我来说,创建 SomeClassCollection COM 兼容对象的最明显方法是继承一些通用的 .NET 集合,例如 List(Of SomeClass),然后创建添加专用函数以及使基本函数和属性 COM 可见(例如,添加、删除、计数等)
因为我继承了一个 .NET 集合,其中每个都受支持(在 .NET 中),所以我认为有可能以某种方式将此功能转移到 COM 集合类(参见工作表、工作簿等集合在支持每个的 Excel 中)。