首頁 > web前端 > js教程 > 主體

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

Susan Sarandon
發布: 2024-11-19 18:45:03
原創
341 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板