您的位置:首页 > Web前端 > JavaScript

在WebBrowser控件使用js调用C#方法

2017-03-17 14:20 691 查看

有时我们需要在WebBrowser控件中嵌入了网页,然后通过html页面调用后台方法,如何实现呢?其实很简单,主要有三步:

  1. 在被调用方法所属的类上加上[ComVisible(true)]标签,意思就是当前类可以以com组件的形式供外部调用。
  2. 在WebBrowser控件中设置可被html页面调用的类即:webBrowser1.ObjectForScripting = this。前端即可通过window.external访问this对象
  3. html页面调用后台方法:window.external.方法名()。此处的window.external相当于webBrowser1.ObjectForScripting

示例代码:

一、后台

using System;
using System.Runtime.InteropServices;
using System.Windows.Forms;

namespace jsInWebBrowserCallCSharpMethod
{
[ComVisible(true)] //1、必须设置且为true,否则设置webBrowser1.ObjectForScripting对象时会报错
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();

webBrowser1.Url =new Uri( Application.StartupPath + "\\htmls\\test.html");
webBrowser1.ObjectForScripting = this;//2、设置js中window.external对象代表的类
}

/// <summary>
/// 供webBrowser页面中js调用的方法
/// </summary>
/// <param name="msg"></param>
/// <param name="msg2"></param> public void ShowMessage(string msg, string msg2) { MessageBox.Show(msg + "\r\n" + msg2); } } }

二、test.html文件

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>测试调用winform后台方法页面</title>
<script type="text/javascript">
window.onload = function () {
var btn = document.getElementById('btnCallCSharpMethod');
btn.onclick = function () {
//此处window.external相当于winform中设置的webBrowser.ObjectForScripting对象
window.external.ShowMessage('成功调用winform类中的方法!','成功调用winform类中的方法2!');
}
}
</script>
</head>
<body style='text-align:center;'>
<input type='button' id='btnCallCSharpMethod' value='调用winform类中的方法' />
</body>
</html>

三、运行效果

 

本文转载自:http://blog.csdn.net/taoerchun/article/details/49782739

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: