WebBrowser.InvokeScript Methode

Definition

Führt eine Skriptfunktion aus, die im derzeit geladenen Dokument definiert ist.

Überlädt

InvokeScript(String)

Führt eine Skriptfunktion aus, die vom derzeit geladenen Dokument implementiert wird.

InvokeScript(String, Object[])

Führt eine Skriptfunktion aus, die im derzeit geladenen Dokument definiert ist.

InvokeScript(String)

Führt eine Skriptfunktion aus, die vom derzeit geladenen Dokument implementiert wird.

public:
 System::Object ^ InvokeScript(System::String ^ scriptName);
public object InvokeScript (string scriptName);
member this.InvokeScript : string -> obj
Public Function InvokeScript (scriptName As String) As Object

Parameter

scriptName
String

Der Name der auszuführenden Skriptfunktion.

Gibt zurück

Das Objekt, das durch den Active Scripting-Aufruf zurückgegeben wurde.

Ausnahmen

Die WebBrowser-Instanz ist nicht mehr gültig.

Ein Verweis auf den zugrunde liegenden systemeigenen WebBrowser konnte nicht abgerufen werden.

Die Skriptfunktion ist nicht vorhanden.

Beispiele

Das folgende Beispiel zeigt, wie eine Skriptfunktion in einem Dokument aus einer WPF-Anwendung mithilfe InvokeScript(String)von aufgerufen wird. In diesem Beispiel verfügt die Skriptfunktion über keine Parameter.

Im Folgenden finden Sie das HTML-Dokument, das die Skriptfunktion implementiert, die von WPF aufgerufen wird.

<html>  
    <head>  
        <script type="text/javascript">  
            // Function Without Parameters  
            function JavaScriptFunctionWithoutParameters()    
            {  
              outputID.innerHTML = "JavaScript function called!";  
            }  
        </script>  
    </head>  
    <body>  
    <div id="outputID" style="color:Red; font-size:16">  
        Hello from HTML document with script!  
    </div>  
    </body>  
</html>  

Im Folgenden wird die WPF-Implementierung zum Aufrufen der Skriptfunktion im HTML-Dokument veranschaulicht.

private void callScriptFunctionNoParamButton_Click(object sender, RoutedEventArgs e)  
{  
  // Make sure the HTML document has loaded before attempting to  
  // invoke script of the document page. You could set loadCompleted  
  // to true when the LoadCompleted event on the WebBrowser fires.  
  if (this.loadCompleted)  
  {  
    try  
    {  
      this.webBrowser.InvokeScript("JavaScriptFunctionWithoutParameters");  
    }  
    catch (Exception ex)  
    {  
      string msg = "Could not call script: " +  
                   ex.Message +  
                  "\n\nPlease click the 'Load HTML Document with Script' button to load.";  
      MessageBox.Show(msg);  
    }  
  }  
}  

Hinweise

InvokeScript(String) sollte nicht aufgerufen werden, bevor das Dokument, das es implementiert, geladen wurde. Sie können erkennen, wann das Laden eines Dokuments abgeschlossen ist, indem Sie das LoadCompleted Ereignis behandeln.

Gilt für:

InvokeScript(String, Object[])

Führt eine Skriptfunktion aus, die im derzeit geladenen Dokument definiert ist.

public:
 System::Object ^ InvokeScript(System::String ^ scriptName, ... cli::array <System::Object ^> ^ args);
[System.Security.SecurityCritical]
public object InvokeScript (string scriptName, params object[] args);
public object InvokeScript (string scriptName, params object[] args);
[<System.Security.SecurityCritical>]
member this.InvokeScript : string * obj[] -> obj
member this.InvokeScript : string * obj[] -> obj
Public Function InvokeScript (scriptName As String, ParamArray args As Object()) As Object

Parameter

scriptName
String

Der Name der auszuführenden Skriptfunktion.

args
Object[]

Die an die Skriptfunktion zu übergebenden Parameter.

Gibt zurück

Das Objekt, das durch den Active Scripting-Aufruf zurückgegeben wurde.

Attribute

Ausnahmen

Die WebBrowser-Instanz ist nicht mehr gültig.

Ein Verweis auf den zugrunde liegenden systemeigenen WebBrowser konnte nicht abgerufen werden.

Die Skriptfunktion ist nicht vorhanden.

Beispiele

Im folgenden Beispiel wird gezeigt, wie Skriptfunktionen in einem Dokument aus einer Anwendung mithilfe InvokeScript(String, Object[])von aufgerufen werden. In diesem Beispiel erfordern die Skriptfunktionen Parameter.

Im Folgenden finden Sie das Dokument, das die Skriptfunktionen implementiert, die von WPF aufgerufen werden.

<html>  
    <head>  
        <script type="text/javascript">  
            // Function Without Parameters  
            function JavaScriptFunctionWithoutParameters()    
            {  
              outputID.innerHTML = "JavaScript function 'called: " + message + ".";  
            }  
        </script>  
    </head>  
    <body>  
    <div id="outputID" style="color:Red; font-size:16">  
        Hello from HTML document with script!  
    </div>  
    </body>  
</html>  

Im Folgenden wird die WPF-Implementierung zum Aufrufen der Skriptfunktionen im HTML-Dokument veranschaulicht.

private void callScriptFunctionNoParamButton_Click(object sender, RoutedEventArgs e)  
{  
  // Make sure the HTML document has loaded before attempting to  
  // invoke script of the document page. You could set loadCompleted  
  // to true when the LoadCompleted event on the WebBrowser fires.  
  if (this.loadCompleted)  
  {  
    try  
    {  
      this.webBrowser.InvokeScript("JavaScriptFunctionWithoutParameters", this.messageTextBox.Text);  
    }  
    catch (Exception ex)  
    {  
      string msg = "Could not call script: " +  
                   ex.Message +  
                  "\n\nPlease click the 'Load HTML Document with Script' button to load.";  
      MessageBox.Show(msg);  
    }  
  }  
}  

Hinweise

InvokeScript(String, Object[]) sollte nicht aufgerufen werden, bevor das Dokument, das es implementiert, geladen wurde. Sie können erkennen, wann das Laden eines Dokuments abgeschlossen ist, indem Sie das LoadCompleted Ereignis behandeln.

Wenn Sie nicht genügend Parameterwerte an das Skript übergeben, das Sie aufrufen, erhalten die Parameter, an die Sie keine Werte übergeben, den undefinierten Wert. Wenn Sie zu viele Parameterwerte übergeben, werden die überschüssigen Werte ignoriert.

Gilt für: