繁体   English   中英

带参数的 OnAction

[英]OnAction with parameters

这是我关于 SO 的第一个问题,即使我经常来这里(直到今天我总是能找到我的答案)。 我知道我已经发布了这个问题,但由于某种原因我不适合我。

我试图获得一个右键单击子菜单,其中包含我的 Word 文档中每个编号项目的列表。 它的目的是在我的文档中插入我的编号项目的编号和内容文本。

问题是我不知道如何使用不同的变量(一个对于每个编号的项目)。 我的报价可能有问题,但我看不到任何其他解决方案。

我的代码如下:

Option Explicit

Sub ControlButtonNumberedItems()

'Parameters for NumberedItems
Dim i As Integer
i = 1
Dim NumberedItems As Integer
NumberedItems = ActiveDocument.CountNumberedItems

'Parameters for CommanBar
Dim MenuButton As CommandBar
Set MenuButton = Application.CommandBars("Text")
Dim SubMenuButton As CommandBarControl
Set SubMenuButton = MenuButton.Controls.Add(Type:=msoControlPopup, Before:=1)

With SubMenuButton
    .Caption = "NumberedItems"
    .Tag = "My_Tag"

    While i <= NumberedItems
        With .Controls.Add(Type:=msoControlButton)
            .OnAction = "'InsertNumberedItem""i""'"
            .FaceId = 38
            .Caption = "MyCaption"
        End With
        i = i + 1
    Wend

End With

End Sub

Sub InsertEvidence(i As Integer)

'Insert NumberRelativeContext
Selection.InsertCrossReference ReferenceType:=wdRefTypeNumberedItem, _
ReferenceKind:=wdNumberRelativeContext, _
ReferenceItem:=i, _
InsertAsHyperlink:=True, _
SeparatorString:=" "

Selection.TypeText Text:=" "

'Insert ContentText
Selection.InsertCrossReference ReferenceType:=wdRefTypeNumberedItem, _
ReferenceKind:=wdContentText, _
ReferenceItem:=i, _
InsertAsHyperlink:=True, _
SeparatorString:=" "

'Text form
Selection.Expand Unit:=wdLine
Selection.Font.Bold = wdToggle
Selection.Font.Italic = wdToggle
Selection.ParagraphFormat.Alignment = wdAlignParagraphRight
Selection.ParagraphFormat.SpaceBefore = 6

End Sub

Sub ResetRightClick()
Application.CommandBars("Text").Reset 
End Sub

预先感谢您的任何帮助。 如果您需要任何其他信息,请告诉我。

我不知道 Word VBA 与 Excel 不同:请参阅此处接受的答案:

VBA 通过 .onAction 传递参数

这对我有用(只是显示如何传递参数所需的代码):

Sub ControlButtonNumberedItems()

    Dim i As Integer
    Dim NumberedItems As Integer

    'Parameters for CommanBar
    Dim MenuButton As CommandBar
    Set MenuButton = Application.CommandBars("Text")
    Dim SubMenuButton As CommandBarControl
    Set SubMenuButton = MenuButton.Controls.Add(Type:=msoControlPopup, Before:=1)

    With SubMenuButton
        .Caption = "NumberedItems"
        .Tag = "My_Tag"

        For i = 1 To 5
            With .Controls.Add(Type:=msoControlButton)
                .OnAction = "InsertNumberedItem"
                .FaceId = 38
                .Parameter = i
                .Caption = "MyCaption " & i
            End With
        Next i

    End With

End Sub

Public Sub InsertNumberedItem()
    MsgBox "got " & CommandBars.ActionControl.Parameter
End Sub

Sub ResetRightClick()
    Application.CommandBars("Text").Reset
End Sub

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM