現在C#越來越多朋友使用了,大家都知道.Net可以開發winform與webform頁面,有時候在開發項目過程中要結合BS+CS這樣來應用,那麼本站做一個實例來測試winform與webform互相通訊的實例,下面先看下效果:

winform調用bs頁面的JS函數效果圖

webform頁面發送信息到winform效果圖
好了,看完上面的效果,下面我們看下如何實現吧。
第一、打開VS2008創建winform項目,之後在MainForm拖入浏覽器控件,並命令這個浏覽器控件名為:WebContainer
下面是全部CS端代碼:
Code [http://www.xueit.com]/*
*
* 名稱:CS與BS互相通訊
* 作者:dodo
* 官方:www.xueit.com
*
*/
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace TestJSWin
{
[System.Runtime.InteropServices.ComVisibleAttribute(true)]
public partial class MainForm : Form
{
public MainForm()
{
InitializeComponent();
this.WebContainer.ObjectForScripting = this; //這句很關鍵,主要和頁面的JS互相操作
Uri uriSale = new System.Uri("http://localhost:8012/index.htm"); //浏覽器控件默認打開頁面
WebContainer.Url = uriSale;
}
/// <summary>
/// 菜單點擊事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void JSEventToolStripMenuItem_Click(object sender, EventArgs e)
{
WebContainer.Navigate("Javascript:fn_test();void(0);");
}
/// <summary>
/// BS調用方法
/// </summary>
/// <param name="strShow"></param>
public void JavascriptCall(string strShow)
{
MessageBox.Show(strShow);
}
}
}
好,做完winform,下面是http://localhost:8012/index.htm頁面的做法。
第2、webform的頁面,源碼很簡單,你可以直接復制源代碼到本地測試就可以了。下面是Html頁面源代碼:
Code [http://www.xueit.com]<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<Html>
<head>
<title>Test JS event</title>
<script language="javascript" type="text/Javascript">
<!--
function fn_test() {
alert("Hello, cs調用JS成功-學it網www.xueit.com歡迎你");
}
function fn_call() {
window.external.JavascriptCall("bs發送信息到winform成功");
}
-->
</script>
</head>
<bo
dy> NET中winform與webform互相通訊實例-www.xueit.com(學IT網歡迎你訪問) <input type="button" value="Call Winform Methed" onclick="fn_call()" /> </body> </Html>嗯!到現在為此,所有操作都可以了,非常簡單,如果你有興趣來按上面的代碼來測試下!
作者:dodo
出處:http://www.xueit.com/html/2009-12-11/21-1046653925703.Html
本文版權歸作者和學IT網共有,歡迎轉載,但未經作者同意必須保留此段聲明,並且保留原文鏈接。否則保留追究法律責任的權利。