欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript與C# Windows應(yīng)用程序交互方法

 更新時間:2007年06月29日 00:00:00   作者:  
一、建立網(wǎng)頁


<html>
<head>
      <meta http-equiv="Content-Language" content="zh-cn">
      <script language="javascript" type="text/javascript">
             <!-- 提供給C#程序調(diào)用的方法 -->
             function messageBox(message)
             {
                   alert(message);
            }
      </script>
</head>

<body>
      <!-- 調(diào)用C#方法 -->
      <button onclick="window.external.MyMessageBox('javascript訪問C#代碼')" >
      javascript訪問C#代碼</button>
</body>
</html>


二、建立Windows應(yīng)用程序

1.       創(chuàng)建Windows應(yīng)用程序項目

2.       在Form1窗體中添加WebBrowser控件

3.       在Form1類的上方添加

[System.Runtime.InteropServices.ComVisibleAttribute(true)]

這是為了將該類設(shè)置為com可訪問。如果不進行該聲明將會出錯。出錯信息如下圖所示:



如:

[System.Runtime.InteropServices.ComVisibleAttribute(true)]

public partial class Form1 : Form



4.初始化WebBrowser的Url與ObjectForScripting兩個屬性。

Url屬性:WebBrowser控件顯示的網(wǎng)頁路徑

ObjectForScripting屬性:該對象可由顯示在WebBrowser控件中的網(wǎng)頁所包含的腳本代碼訪問。

將Url屬性設(shè)置為需要進行操作的頁的URL路徑。

JavaScript通過window.external調(diào)用C#公開的方法。即由ObjectForScripting屬性設(shè)置的類的實例中所包含的公共方法。具體設(shè)置例子如下:

System.IO.FileInfo file = new System.IO.FileInfo("index.htm");

// WebBrowser控件顯示的網(wǎng)頁路徑

webBrowser1.Url = new Uri(file.FullName);

// 將當(dāng)前類設(shè)置為可由腳本訪問

webBrowser1.ObjectForScripting = this;



5.C#調(diào)用JavaScript方法

通過WebBrowser類的Document屬性中的InvokeScript方法調(diào)用當(dāng)前網(wǎng)頁的Javascript方法。如:

// 調(diào)用JavaScript的messageBox方法,并傳入?yún)?shù)

object[] objects = new object[1];

objects[0] = "C#訪問JavaScript腳本";

webBrowser1.Document.InvokeScript("messageBox", objects);



完整代碼如下:


[System.Runtime.InteropServices.ComVisibleAttribute(true)]

public partial class Form1 : Form

{

   public Form1()

   {

       InitializeComponent();

       System.IO.FileInfo file = new System.IO.FileInfo("index.htm");

       // WebBrowser控件顯示的網(wǎng)頁路徑

       webBrowser1.Url = new Uri(file.FullName);

       // 將當(dāng)前類設(shè)置為可由腳本訪問

       webBrowser1.ObjectForScripting = this;

   }



   private void button1_Click(object sender, EventArgs e)

    {

       // 調(diào)用JavaScript的messageBox方法,并傳入?yún)?shù)

       object[] objects = new object[1];

       objects[0] = "C#訪問JavaScript腳本";

       webBrowser1.Document.InvokeScript("messageBox", objects);

   }

   // 提供給JavaScript調(diào)用的方法

   public void MyMessageBox(string message)

   {

       MessageBox.Show(message);
   }
}



Dnew.cn 注:原文:http://www.cnblogs.com/xds/archive/2007/03/02/661838.html

相關(guān)文章

  • JS實現(xiàn)六位字符密碼輸入器功能

    JS實現(xiàn)六位字符密碼輸入器功能

    這篇文章主要介紹了JS實現(xiàn)六位字符密碼輸入器功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • js特效,頁面下雪的小例子

    js特效,頁面下雪的小例子

    js特效,頁面下雪的小例子,需要的朋友可以參考一下
    2013-06-06
  • js控制fieldset高度的代碼

    js控制fieldset高度的代碼

    js控制fieldset高度的代碼...
    2007-11-11
  • node.js+express+mySQL+ejs+bootstrop實現(xiàn)網(wǎng)站登錄注冊功能

    node.js+express+mySQL+ejs+bootstrop實現(xiàn)網(wǎng)站登錄注冊功能

    這篇文章主要介紹了node.js+express+mySQL+ejs+bootstrop實現(xiàn)網(wǎng)站登錄注冊功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • 元素未顯示設(shè)置width/height時IE中使用currentStyle獲取為auto

    元素未顯示設(shè)置width/height時IE中使用currentStyle獲取為auto

    元素未顯示設(shè)置width/height時IE中無法使用currentStyle獲取,默認(rèn)獲取值為auto,需要的朋友可以參考下
    2014-05-05
  • 微信小程序?qū)崿F(xiàn)活動報名登記功能(實例代碼)

    微信小程序?qū)崿F(xiàn)活動報名登記功能(實例代碼)

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)活動報名登記,本篇將介紹使用微信小程序?qū)崿F(xiàn)發(fā)起一個活動報名的設(shè)計,以此為基礎(chǔ),我們可以掌握微信小程序表單的基本用法,進而在諸如疫情信息登記、出入報備等場景中使用小程序進行開發(fā),滿足相關(guān)的需求,需要的朋友可以參考下
    2022-09-09
  • ES6 Promise對象的應(yīng)用實例分析

    ES6 Promise對象的應(yīng)用實例分析

    這篇文章主要介紹了ES6 Promise對象的應(yīng)用,結(jié)合實例形式分析了Promise對象原理與異步處理相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • 基于JS實現(xiàn)前端壓縮上傳圖片的實例代碼

    基于JS實現(xiàn)前端壓縮上傳圖片的實例代碼

    這篇文章主要介紹了基于JS實現(xiàn)前端壓縮上傳圖片的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05
  • JS如何尋找數(shù)組中心索引過程解析

    JS如何尋找數(shù)組中心索引過程解析

    這篇文章主要介紹了JS如何尋找數(shù)組中心索引過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • javascript執(zhí)行上下文詳解

    javascript執(zhí)行上下文詳解

    執(zhí)行上下文可以說是js代碼執(zhí)行的一個環(huán)境,存放了代碼執(zhí)行所需的變量,變量查找的作用域鏈規(guī)則以及this指向等。同時,它也是js很底層的東西,很多的問題如變量提升、作用域鏈和閉包等都可以在執(zhí)行上下文中找到答案,所以這也是我們學(xué)習(xí)執(zhí)行上下文的原因
    2023-05-05

最新評論