首頁 >web前端 >js教程 >如何在不使用 InnerHtml 的情況下將 JavaScript 注入 Web 瀏覽器控制項?

如何在不使用 InnerHtml 的情況下將 JavaScript 注入 Web 瀏覽器控制項?

Susan Sarandon
Susan Sarandon原創
2024-11-19 18:45:03384瀏覽

How to Inject JavaScript into a WebBrowser Control Without Using InnerHtml?

將JavaScript 注入Web 瀏覽器控制

問題:

問題:

我正在嘗試注入Script腳本插入WebBrowser 控件,但在設定腳本的InnerHtml 屬性時遇到錯誤元素。有沒有替代方法來實現這一點?

答案:
HtmlElement head = webBrowser1.Document.GetElementsByTagName("head")[0];
HtmlElement scriptEl = webBrowser1.Document.CreateElement("script");
IHTMLScriptElement element = (IHTMLScriptElement)scriptEl.DomElement;
element.text = "function sayHello() { alert('hello') }";
head.AppendChild(scriptEl);
webBrowser1.Document.InvokeScript("sayHello");

雖然原始嘗試失敗成功,但可以使用以下方法將腳本注入DOM:

  • 說明:

    • 取得IHTMLScriptElement 介面:
  • DomElement 屬性公開底層 COM 物件。將其轉換為 IHTMLScriptElement 可以存取文字屬性。

    • 設定腳本文字:
  • 分配所需的 JavaScript程式碼到正文

    • 呼叫腳本:
在文件上呼叫 InvokeScript 來執行注入的腳本。

以上是如何在不使用 InnerHtml 的情況下將 JavaScript 注入 Web 瀏覽器控制項?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn