首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在webbrowser控件中注入和执行不修改文档的javascript函数?

如何在webbrowser控件中注入和执行不修改文档的javascript函数?
EN

Stack Overflow用户
提问于 2014-02-19 05:14:06
回答 2查看 1.3K关注 0票数 2

我可以简单地做:

代码语言:javascript
运行
复制
object DomElement = ChooseMyDomElement(webBrowser1);  //this is a ID less element
webBrowser1.DocumentText = NewDocumentTextWithInjectedJavaScriptFunction;
webBrowser1.Document.InvokeScript("myfnc", DomElement);

但是,我不想对加载的文档进行任何修改,比如设置DocumentText、创建一个新的脚本元素等等。

我试过:

代码语言:javascript
运行
复制
object DomElement = ChooseMyDomElement(webBrowser1);  //this is a ID less element
var js = "function myfnc(r) {alert(r);}  myfnc(" + DomElement +");"; //DomElement is converted to string!
webBrowser1.Document.InvokeScript("eval", new object[] { js });

问题在于,java将DomElement视为字符串!

我希望发送带有javascript函数的DomElement对象,以便在脚本中的DomElement上进行处理。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-19 05:38:26

试试这个:

代码语言:javascript
运行
复制
void webBrowser1_DocumentCompleted(object sender, WebBrowserDocumentCompletedEventArgs e)
{
    var anyScripts = webBrowser1.Document.GetElementsByTagName("script");
    if (anyScripts == null || anyScripts.Count == 0)
    {
        // at least one <script> element must be present for eval to work
        var script = webBrowser1.Document.CreateElement("script");
        webBrowser1.Document.Body.AppendChild(script);
    }

    // use anonymous functions

    dynamic func = webBrowser1.Document.InvokeScript("eval", new[] { 
        "(function() { return function(elem, color) { elem.style.backgroundColor = color; } })()" });

    var body = this.webBrowser1.Document.Body.DomElement;

    func(body, "red");
}
票数 3
EN

Stack Overflow用户

发布于 2014-02-19 05:19:22

这样的东西应该在控件中执行javascript,而不必修改文档:

代码语言:javascript
运行
复制
 BrowserControl.Navigate("javascript:function test(){console.log('test');}test();")
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21871643

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档