在开发中我们经常将WebBrowser控件嵌入Winform 程序来浏览网页,既然是网页那么少不了JS。下面就让我们来说说他们两之间的相互调用。

在C#封装的浏览器内核中,Chromium 内核封装有Xilium.Cefglue、Cefsharp,Webkit 内核封装 Webkit.Net 、OpenWebKitSharp等。

但是说到和JS的调用,不得不说还是IE 的WebBrowser 最为简单方便。至于IE 为啥方便而其他的不方便,以后我会写文章分析。

下面我们还是先看看WebBrowser怎么和JS交互把:

WebBrowser 执行JS 代码

如果脚本已经存在于网页中,我们可以使用 InvokeScript 方法

public object InvokeScript(string scriptName)
public object InvokeScript(string scriptName,object[] args)

下面是一个简单例子:

  1. <HTML>
  2. <HEAD>
  3. <TITLE>Invoke Script Sample</TITLE>
  4. <SCRIPT>
  5. //无参数调用
  6. function alertNull(){
  7. alert("WebBrowser call!");
  8. }
  9. //有参数调用
  10. function callWithPar(name, address) {
  11. alert("Name is " + name + "; address is " + address);
  12. }
  13. //返回字符串
  14. function returnString() {
  15. return("This is a test.");
  16. }
  17. //返回对象
  18. function returnScriptObject() {
  19. return(new(MyObject));
  20. }
  21. function MyObject() {
  22. this.Data = "Data for my private object.";
  23. }
  24. </SCRIPT>
  25. </HEAD>
  26. <BODY>
  27. <DIV id="div1">
  28. </DIV>
  29. </BODY>
  30. </HTML>
  1. private void button2_Click(object sender, EventArgs e)
  2. {
  3. string name = "dai";
  4. string address = "123";
  5. if (webBrowser1.Document != null)
  6. {
  7. HtmlDocument doc = webBrowser1.Document;
  8. //无参调用
  9. doc.InvokeScript("alertNull");
  10. Object[] objArray = new Object[2];
  11. objArray[0] = (Object)name;
  12. objArray[1] = (Object)address;
  13. //有参调用
  14. doc.InvokeScript("callWithPar", objArray);
  15. //返回字符串
  16. String str = doc.InvokeScript("returnString").ToString();
  17. MessageBox.Show(str);
  18. //返回对象
  19. Object jscriptObj = doc.InvokeScript("returnScriptObject");
  20. MessageBox.Show(jscriptObj.ToString());
  21. }
  22. }

如果网页中不存在目标脚本,我们也可以创建脚本再执行。

  1. HtmlElement ele = webBrowser1.Document.CreateElement("script");
  2. ele.SetAttribute("type", "text/javascript");
  3. ele.SetAttribute("text", "alert('new script')");
  4. webBrowser1.Document.Body.AppendChild(ele);

相当于更改Html 的DOM结构,在<Body>标签后添加<Script>标签,程序加载最后会执行text 中的JS代码。

JS 调用 C# 方法

接下来,我们来说说今天的重点,在JS中怎么调用C# 提供的方法。

public object ObjectForScripting {
get;
[SecurityCriticalAttribute]
set;
}

public 类的实例的 Object,由主机应用程序实现且可由寄宿文档的脚本访问。

有了这个方法,调用C#方法就很简单,只需要在C#中声明一个C#对象,然后再设置 this.webBrowser1.ObjectForScripting = new JSObject();  就OK了。

记得要在JSObject 类上面声明 [System.Runtime.InteropServices.ComVisible(true)] 才能使对象可见。

设置完了之后,就可以在JS 中使用Window.external.function();调用JSObject()的function() 方法了。

下面是一个例子:

  1. <HTML>
  2. <HEAD>
  3. <TITLE>Invoke C# Sample</TITLE>
  4. </HEAD>
  5. <BODY>
  6. <DIV id="div1">
  7. </DIV>
  8. <SCRIPT>
  9. window.external.CallShow();
  10. //传参数
  11. window.external.ShowSomething("Hello");
  12. //返回值
  13. var msg = window.external.returnSomething("Hello");
  14. alert(msg);
  15. //直接获取变量
  16. alert(window.external.a);
  17. </SCRIPT>
  18. </BODY>
  19. </HTML>
  1. [System.Runtime.InteropServices.ComVisible(true)]
  2. public class JSObject
  3. {
  4. // 无参数,无返回值
  5. public void CallShow()
  6. {
  7. MessageBox.Show("Called from JS");
  8. }
  9. //无返回值,有参数
  10. public void ShowSomething(String msg)
  11. {
  12. MessageBox.Show("Called from " + msg);
  13. }
  14. //有返回值,有参数
  15. public string returnSomething(String msg)
  16. {
  17. msg += "From C#";
  18. return msg;
  19. }
  20. //直接获取变量
  21. public string a = "A";
  22. }

简单的传值就是这样实现的,但是对于复杂对象传递,涉及到JS对象和C#对象转换,并不是很方便,能用字符串的还是用字符串吧。

用JSON传递是个不错的选择,C#和JS中都有JSON转换工具,可以试试。

以上!

WebBrowser(IE) 与 JS 相互调用的更多相关文章

  1. 关于action script与js相互调用的Security Error问题

    大家都知道,as和js相互调用可以通过ExternalInterface.call和ExternalInterface.addCallback来进行. 比较好的做法是使用之前通过ExternalInt ...

  2. CefSharp 与 js 相互调用及注意事项

    CefSharp 与 js 相互调用 一. CefSharp调用 js CefSharp.WinForms.ChromiumWebBrowser wb; ... 方式1. ExecuteScriptA ...

  3. WebView使用详解(一)——Native与JS相互调用(附JadX反编译)

    念念不忘,必有回响,永远坚持你所坚持的! 一直在用WebView,还没有系统的总结过它的用法,下面就系统的总结下,分享给大家 一.基本用法 1.加载在线URL void loadUrl(String ...

  4. flex与js相互调用

    1.flex调用js方法 调用方法例如:ExternalInterface.call("UploadComplete",oldName,uidName,_dir+"/&q ...

  5. Android js相互调用

    一.webview相当于android中的浏览器,基于webkit开发,可以浏览网页文件,支持css javas cript 以及html webview.getSettings().setJavaS ...

  6. 【转】CefSharp 与 js 相互调用

    转自CSDN博客博主ghui,虽然博主说要经过他同意才能转,我只是做笔记用,没做他用,所以请博主理解,在此感谢博主! 一. CefSharp调用 js CefSharp.WinForms.Chromi ...

  7. CefSharp 与 js 相互调用

    https://blog.csdn.net/gong_hui2000/article/details/48155547

  8. WinForm中嵌入WebBrowser,并且支持C#和JS方法的相互调用

    纯粹WinForm界面不够友好,实现数据复杂度高的处理有些力不从心,所以看了看api以后决定用html来做. 我的wlw的代码插件不是很好用,大家凑合看吧 类前说明引用和权限 1: [Permissi ...

  9. JS代码和OC代码的相互调用

    JS调用OC 很多应用里面或多或少的调用了网页,来达到绚丽的效果,所谓的JS调用OC.....举个例子吧,网页上有个按钮 点击按钮跳转界面,跳转的动作由OC的代码实现. OC调用JS 还是举个例子,我 ...

随机推荐

  1. uiautomatorviewer 优化定位符生成,支持生成Java,Python自动化代码

    项目介绍 二次开发 uiautomatorviewer 优化定位符生成,支持生成Java,Python自动化代码,修复自带工具画面有动态加载时截图失败问题,优化自带工具截图速度 ,实现类似录制脚本功能 ...

  2. 架构(四)Git简介,安装以及相关命令SourceTree

    一 Git介绍 1.1 Git是什么? Git是一个分布式版本控制软件: 版本控制:假如开发人员开发了一个a功能,结果项目经理觉得不够需要修改,开发人员又改成了b功能,后来又改成了c功能,但是最终项目 ...

  3. Go语言结构

    目录 结构体定义 创建结构体实例 普通方式创建结构体实例 new()创建结构体实例 结构体实例初始化 结构体类型实例和指向它的指针内存布局 结构体的方法 面向对象 组合(继承) 结构体使用注意事项 G ...

  4. 《http权威指南》读书笔记8

    概述 最近对http很感兴趣,于是开始看<http权威指南>.别人都说这本书有点老了,而且内容太多.我个人觉得这本书写的太好了,非常长知识,让你知道关于http的很多概念,不仅告诉你怎么做 ...

  5. base64编解码学习及python代码实现

    Base64是一种用64个字符来表示任意二进制数据的方法. Base64编码可以成为密码学的基石.可以将任意的二进制数据进行Base64编码.所有的数据都能被编码为并只用65个字符就能表示的文本文件. ...

  6. 【Spark调优】内存模型与参数调优

    [Spark内存模型] Spark在一个executor中的内存分为3块:storage内存.execution内存.other内存. 1. storage内存:存储broadcast,cache,p ...

  7. python(leetcode)-重复元素算法题

    leetcode初级算法 问题描述 给定一个整数数组,判断是否存在重复元素. 如果任何值在数组中出现至少两次,函数返回 true.如果数组中每个元素都不相同,则返回 false. 该问题表述非常简单 ...

  8. 【ABP框架系列学习】启动配置(5)

    ABP提供了在启动时配置模块的基础设施和模型. 1.配置ABP 配置ABP是在模块的PreInitialize方法中完成的,例如: public class SimpleTaskSystemModul ...

  9. Google Chrome 书签导出并生成 MHTML 文件

    目的 因为某些原因需要将存放在 Google Chrome 内的书签导出到本地,所幸 Google Chrome 提供了导出书签的功能. 分析 首先在 Google Chrome 浏览器当中输入 ch ...

  10. failed to create pid file /var/run/rsyncd.pid: File exists报错

    [root@pcidata-jenkins ansible_playbooks]# ps aux|grep rsyncroot      1799  0.0  0.0 114652   480 ?   ...