自 Build 8201.2025 起,在 Word 中加载带有功能区的 VSTO 插件时,事件顺序发生了意外更改。
- 使用 Office 版本 16.0.8067.2115 或更早版本。加载插件时,会观察到以下事件顺序(一直如此)。
Ribbon_Load event
ThisAddin_Startup event
- 使用 Office 版本 8201.2025、8201.2064 或 8201.2075 或更高版本,事件顺序会颠倒,这是意外的重大更改。
ThisAddin_Startup event
Ribbon_Load event
- 我使用可视化设计器功能区创建了一个简单的 VSTO 插件来演示该问题。
>
Public Class Ribbon1
Private Sub Ribbon1_Load(ByVal sender As System.Object, ByVal e As RibbonUIEventArgs) Handles MyBase.Load
System.Diagnostics.Debug.Write("Ribbon1_Load event called.")
'Pass the Ribbon to the Addin.
ThisAddIn.MyRibbon = Me
End Sub
End Class
Public Class ThisAddIn
Public Shared Property MyRibbon As Ribbon1 = Nothing
Private Sub ThisAddIn_Startup() Handles Me.Startup
Debug.Write("ThisAddin_Startup Called")
If (MyRibbon Is Nothing) Then
Debug.Write("MyRibbon is nothing - the ribbon was not captured.")
Else
Debug.Write("Ribbon captured successfully.")
End If
End Sub
End Class
16.0.8067.2115 32 位的调试输出
[7772] 调用 Ribbon1_Load 事件。
[7772] 调用了 ThisAddin_Startup
[7772] 功能区已成功捕获。
16.0.8201.2075 32 位的调试输出
- [13556] 调用了 ThisAddin_Startup
- [13556] MyRibbon 没什么用 - 功能区未捕获。
- [13556] 调用 Ribbon1_Load 事件
我已将其发布在Microsoft Support forums上但是他们已经停止响应,自从将此版本发布到当前办公 channel 后,我需要开发社区的帮助。
有人找到成功的解决方法吗?这种时间的改变给我们的初始化方式带来了很多问题。 Microsoft 支持人员最好在调查此错误之前提供解决方案或解决方法。
最佳答案
我总是在 ThisAddin_Startup
之前获得 Ribbon_Load
,因为我使用 Ribbon XML。 Ribbon UI 允许较少的控件...由于两者都是“入口”点,我建议您在启动时仅使用 Ribbon1_Load
。或者,如果您使用 Ribbon XML 模型并且想要第一个入口点,请尝试其构造函数
我不认为这个问题是一个错误,为了使 Word 更快,许多进程都是异步的。因此,在我看来,首先启动的 ThisAddin_Startup
或 Ribbon1_Load
可能会因多种因素而意外更改:系统性能、Word 单独启动、Word 通过文档启动。 .
关于ms-word - 事件顺序颠倒了 'Ribbon_Load' 和 'ThisAddin_Startup' Word VSTO 插件。 (内部版本 8201.2025 及以上),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44937947/