一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在兩個Silverlight應用間應用間數據通信DEMO(包括與Flash通信)

因為Silverlight可以訪問HTML中的DOM元素以及調用HTML頁面中的JS方法,并且可以將自身的方法"暴露"給HTML頁面中的JS方法(通過[ScriptableMember]),所以我們可以利用這一特點來實現兩個Silverlight應用程序之間的數據通信。為了直觀起見,本人做了這個DEMO,希望能夠對大家在理解上有所幫助。

本DEMO的工作流程如下:

Silverlight 1 調用HTML中的JS方法,而該方法會去調用Silverlight 2中“暴露”的方法來顯示選中的數據。

請大家先看一下這個DEMO的運行效果,如下圖所示:

在上圖中分別有兩個Silverlight應用,一個是雇員列表,一個是詳細信息。其中的雇員列表是我以前在園子里發表過的一遍文章中提到的DEMO,這里只是為了便于演示而簡單的加以改造,其雇員類信息如下:

[ScriptableType]
public class EmployeeInfo
{
    
/// <summary>
    
/// 雇員編號
    
/// </summary>
    [ScriptableMember]
    
public int EmployeeNo { getset; }
    
/// <summary>
    
/// 雇員名稱
    
/// </summary>
    [ScriptableMember]
    
public string EmployeeName { getset; }
    
/// <summary>
    
/// 地址
    
/// </summary>
    [ScriptableMember]
    
public string Address { getset; }
}

  上面的ScriptableType,ScriptableMember屬性綁寫是為了讓html中的腳本代碼可以訪問(即可見)。

而下面的代碼則是為了定義一個“腳本對象類”及其事件處理(包括參數)。

/// <summary>
/// 雇員事件參數(用于完成與js綁定事件參數)
/// </summary>
[ScriptableType]
public class EmployeeInfoEventArgs : EventArgs
{
    [ScriptableMember]
    
public EmployeeInfo employeeInfo { getset; }
}

/// <summary>
/// 要注冊并在頁面中使用的js調用腳本對象
/// </summary>
[ScriptableType]
public class JavaScriptableObject
{
    
/// <summary>
    
/// js捆綁的事件處理器
    
/// </summary>
    [ScriptableMember]
    
public event EventHandler<EmployeeInfoEventArgs> SelectEmployeeInfo;

    
public void OnSelectEmployeeInfo(EmployeeInfo employeeinfo)
    {
        
if (SelectEmployeeInfo != null)
        {
            SelectEmployeeInfo(
thisnew EmployeeInfoEventArgs()
            {
                employeeInfo 
= employeeinfo
            });
        }
    }
}

有了數據和數據結構,我們可以在應用程序中給列表控件綁定數據源了,如下:

//這里必須聲明是public,否則js調用該方法時會報錯
[ScriptableMember]
public void LoadData(int count)
{
    
//加載指定數據的雇員信息
    EmployeeList.ItemsSource = new EmployeeManager().GetEmployeeList(count);
}

到這里,基本上DEMO中的主要內容就介紹完了。

下面再給大家演示一個Silverlight與FLASH進行數據通信 的例子,其實現的功能如下:

在Silverlight應用中拖動一張圖片,在右側的FLASH區域中相應的FLASH對象跟著被“移動”,其效果如下圖所示:

 
 
 

其實這個DEMO最初的原型出自微軟件的黃繼佳,我是在一次SILVERLIGHT培訓中看到他這個演示,當時我想實現原理應該與本文所提到的大同小異,后來被證實現確實如此。當然他的演示中實現的JS代碼很簡單,完全就是用純JS來實現即可。我這里并未完全使用了他的模型代碼。因為上面所說的是在CS代碼中進行事件的綁定及其相關操作,所以我還是照上面所提供的思路重新寫了這個DEMO,實現的效果與黃紀佳的原型基本相似。因為篇幅起見,這里就不多做贅述了,大家下載代碼后一看便知(SLImage.xaml.cs和SLtoFlash.htm文件)。

好的,今天的內容就先到這里了。

NET技術在兩個Silverlight應用間應用間數據通信DEMO(包括與Flash通信),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国内精品视频区在线2021 | 欧美午夜性刺激在线观看免费 | gogo人体大胆色妇 | 国产免费资源高清小视频在线观看 | 好吊操在线观看 | 欧美色黄视频 | 美美女高清毛片视频免费观看 | 精品四虎免费观看国产高清 | 福利精品 | 久久亚洲视频 | 国产成人综合网在线播放 | 国产高清免费视频 | 国产精品久久久久久久专区 | 欧美黄视频网站 | 欧美性一交激情视频在线 | 一区二区三区免费在线 | 337p亚洲精品色噜噜狠狠 | 九九亚洲 | 久久久网| 国产成人综合91精品 | 久久er国产精品免费观看2 | 五月天激情婷婷婷久久 | 性视频小说| 色欧美在线视频 | 波多野结衣一区二区三区高清在线 | 久青草国产在线视频亚瑟影视 | 色综合天天操 | 日韩片在线观看 | 婷婷久操 | 亚洲欧洲视频 | 欧美激情视频网址 | 91亚洲精品国产自在现线 | 日本一区二区三区视频在线 | 国产午夜三区视频在线 | 国产精欧美一区二区三区 | 亚洲精品人成网在线播放影院 | 国产91在线免费观看 | 免费一区二区三区四区 | 国产欧美一区二区三区观看 | 2021久久精品国产99国产 | 免费人成综合在线视频 |