程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> .NET中winform與webform互相通訊實例

.NET中winform與webform互相通訊實例

編輯:.NET實例教程

現在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網共有,歡迎轉載,但未經作者同意必須保留此段聲明,並且保留原文鏈接。否則保留追究法律責任的權利。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved