Поделиться через


Метод ShellFolderItem.InvokeVerbEx

Выполняет команду для элемента оболочки.

Синтаксис

iRetVal = ShellFolderItem.InvokeVerbEx(
  [ vVerb ],
  [ vArgs ]
)

Параметры

vVerb [in, необязательный]

Тип: Variant

Тип Variant, содержащий строку глагола, соответствующую выполняемой команде. Это должно быть одно из значений, возвращаемых свойством Name элемента. Если команда не указана, выполняется команда по умолчанию.

vArgs [in, необязательный]

Тип: Variant

Тип Variant, состоящий из строки с одним или несколькими аргументами для команды, заданной vVerb. Формат этой строки зависит от конкретной команды.

Комментарии

Глагол — это строка, используемая для указания определенного действия, которое поддерживает элемент. Как правило, при вызове команды запускается связанное приложение. Например, вызов команды open в файле .txt обычно открывает файл в текстовом редакторе, обычно в Блокноте Майкрософт. Объект FolderItemVerbs представляет коллекцию глаголов, связанных с элементом. Дополнительные сведения о командах см. в разделе Запуск приложений.

Этот метод аналогичен Методу InvokeVerb, но позволяет указать аргументы для команды, а также для самой команды.

Примеры

В следующих примерах показано правильное использование этого метода в JScript, VBScript и Visual Basic.

Jscript:

<script language="JScript">
    function fnFolderItem2InvokeVerbExJ()
    {
        var objShell = new ActiveXObject("shell.application");
        var objFolder2;
        var ssfWINDOWS = 36;
        
        objFolder2 = objShell.NameSpace(ssfWINDOWS);
        if (objFolder2 != null)
        {
            var objFolderItem;
            
            objFolderItem = objFolder2.ParseName("NOTEPAD.EXE");
            if (objFolderItem != null)
            {
                objFolderItem.InvokeVerbEx("open", "c:\\autoexec.bat");
            }
        }
    }
</script>

Vbscript:

<script language="VBScript">
    function fnFolderItemInvokeVerbExVB()
        dim objShell
        
        set objShell = CreateObject("shell.application")
        if (not objShell is nothing) then
            dim objFolder2
            dim ssfWINDOWS
                
            ssfWINDOWS = 36
            set objFolder2 = objShell.NameSpace(ssfWINDOWS)
            if (not objFolder2 is nothing) then
                dim objFolderItem
                        
                set objFolderItem = objFolder2.Self
                if (not objFolderItem is nothing) then
                    objFolderItem.InvokeVerbEx()
                end if
                set objFolderItem = nothing
            end if
            set objFolder2 = nothing
        end if
        set objShell = nothing
    end function
 </script>

Visual Basic:

Private Sub fnFolderItem2InvokeVerbExVB()
    Dim objShell   As Shell
    Dim objFolder2 As Folder2
    Dim ssfWINDOWS As Long
    
    ssfWINDOWS = 36
    Set objShell = New Shell
    Set objFolder2 = objShell.NameSpace(ssfWINDOWS)
        If (Not objFolder2 Is Nothing) Then
            Dim objFolderItem2 As Object
            
            Set objFolderItem2 = objFolder2.ParseName("NOTEPAD.EXE")
                If (Not objFolderItem2 Is Nothing) Then
                    objFolderItem2.InvokeVerbEx ("open")
                Else
                    'FolderItem object returned nothing.
                End If
            Set objFolderItem2 = Nothing
        Else
            'Folder object returned nothing.
        End If
    Set objFolder2 = Nothing
    Set objShell = Nothing
End Sub

Требования

Требование Значение
Минимальная версия клиента
Windows 2000 Professional, Windows XP [только классические приложения]
Минимальная версия сервера
Windows Server 2003 [только классические приложения]
Заголовок
Shldisp.h
IDL
Shldisp.idl
DLL
Shell32.dll (версия 5.0 или более поздняя)

См. также раздел

ShellFolderItem

InvokeVerb