2

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 中)。

4

1 回答 1

3

通常,您需要实现一个 COM 可见类,该类公开一个带有签名的方法,IEnumerator GetEnumerator()并将其标记为 DISPID 为 -4(即 DISPID_NEWENUM)

这里有更详细的解释

于 2012-09-26T09:44:51.423 回答