天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

一步一步學Silverlight :如何在Silverlight中調用JavaScript

概述

Silverlight 2 Beta 1版本發布了,無論從Runtime還是Tools都給我們帶來了很多的驚喜,如支持框架語言Visual Basic, Visual C#, IronRuby, IronPython,對JSON、Web Service、WCF以及Sockets的支持等一系列新的特性?!兑徊揭徊綄WSilverlight 2系列》文章將從Silverlight 2基礎知識、數據與通信、自定義控件、動畫、圖形圖像等幾個方面帶您快速進入Silverlight 2開發。

Silverlight中內置了對于HTML、客戶端腳本等的支持。很多情況下,我們編寫的Web應用程序中用了一些JavaScript或者AJAX框架,我們希望能夠在Silverlight調用某些腳本方法,或者說在Silverlight中觸發某個腳本的執行,這時就需要用到在Silverlight中調用JavaScript,本文將簡單介紹這一內容。

使用GetProperty獲取腳本對象

先來看一個簡單的例子,在Silverlight測試頁面中放入一個div用作顯示信息:

<div id="result"></div>

編寫一段簡單的JavaScript代碼:

<script type="text/Javascript">    function Hello(message)    {        var resultSpan = $get("result");        resultSpan.innerText = "Hello " + message;    }</script>

再編寫一個簡單的輸入信息界面:

<StackPanel Background="#CDFCAE" Orientation="Vertical">    <StackPanel Height="40">        <TextBlock Text="Calling Browser Script from Silverlight"                   Foreground="Red"></TextBlock>    </StackPanel>    <StackPanel Orientation="Horizontal">        <TextBox x:Name="input" Width="340" Height="40" Margin="20 0 20 0"></TextBox>        <Button x:Name="submit" Width="120" Height="40" Background="Red"            Content="調 用" FontSize="20" Foreground="Red" Click="submit_Click"></Button>    </StackPanel></StackPanel>

實現對腳本的調用:

private void submit_Click(object sender, RoutedEventArgs e){    ScriptObject hello = HtmlPage.Window.GetProperty("Hello") as ScriptObject;    hello.InvokeSelf(this.input.Text);}

ScriptObject提供了任何客戶端腳本的封裝,不僅僅是JavaScript,使用其他的AJAX框架也可以,如jQuery等。然后調用InvokeSelf()方法,傳入參數,這里ScriptObject總共提供了兩個方法,Invoke和InvokeSelf,如果我們只調用腳本對象的自身,就可以使用InvokeSelf,如果腳本對象中還有其它的函數等,可以使用Invoke傳入名稱進行調用,兩個方法的定義如下:

[SecuritySafeCritical]public virtual object Invoke(string name, params object[] args);[SecuritySafeCritical]public virtual object InvokeSelf(params object[] args);

運行上面的示例:

 TerryLee_Silverlight2_0097

輸入TerryLee后點擊調用,可以看到確實調用了客戶端腳本:

TerryLee_Silverlight2_0098 

使用CreateInstance創建腳本對象

除了使用上面所說的使用HtmlPage.Window.GetProperty方法獲取腳本對象之外,還有一種替代方法,即使用HtmlPage.Window屬性的CreateInstance方法。還是使用上面的示例,我們在測試頁中加入如下一段腳本,使用prototype為myHello添加了顯示的功能:

<script type="text/Javascript">    myHello = function(message)    {        this.Message = message;    }    myHello.prototype.Display = function()    {        var resultSpan = $get("result");        resultSpan.innerText = "Hello " + this.Message;    }</script>

使用HtmlPage.Window.CreateInstance創建腳本對象

private void submit_Click(object sender, RoutedEventArgs e){    ScriptObject script = HtmlPage.Window.CreateInstance("myHello",this.input.Text);    object result = script.Invoke("Display");}

運行后的效果跟上面的示例是一樣的,如:

TerryLee_Silverlight2_0097

輸入文本信息后:

TerryLee_Silverlight2_0099 

使用HtmlPage.Window.Eval()

最后還有一種機制,就是使用HtmlPage.Window.Eval()方法,只要我們給該方法傳入一段字符串,它都會作為JavaScript來執行。做一個簡單的測試,我們再修改一下上面的示例代碼:

private void submit_Click(object sender, RoutedEventArgs e){    HtmlPage.Window.Eval(this.input.Text);}

運行后我們在文本框中輸入一段腳本alert('TerryLee');,效果如下所示:

TerryLee_Silverlight2_0100

既然HtmlPage.Window.Eval()可以執行一段腳本,并且將執行的結果以對象形式返回,我們可以使用它來獲取DOM元素。如下面這段代碼:

private void submit_Click(object sender, RoutedEventArgs e){    HtmlElement result = HtmlPage.Window.Eval("document.getElementById('result')") as HtmlElement;    string message = result.GetAttribute("innerHTML");    HtmlPage.Window.Alert(message);}

運行后效果如下,獲取的result確實就是我們定義的div。

TerryLee_Silverlight2_0101 

對AJAX框架的支持

前面說過,ScriptObject不僅僅是對JavaScript的封裝,也支持其它的AJAX框架,現在我們用jQuery來測試一下,編寫一小段代碼:

<script type="text/Javascript">    function myHello(message)    {        $("#result").text("Hello " + message);    }</script>

調用腳本

private void submit_Click(object sender, RoutedEventArgs e){    ScriptObject script = HtmlPage.Window.GetProperty("myHello") as ScriptObject;    script.InvokeSelf(this.input.Text);}

運行后的結果與前面的示例是一樣的:

TerryLee_Silverlight2_0102 

結束語

本文介紹了在Silverlight中調用JavaScript的幾種方法,下一篇我將介紹如何在JavaScript中調用Silverlight。

NET技術一步一步學Silverlight :如何在Silverlight中調用JavaScript,轉載需保留來源!

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

主站蜘蛛池模板: 果冻传媒在线观看完整版免费 | 亚洲欧美日韩国产精品26u | 甜性涩爱bt下载 | 国产成人综合网在线观看 | 76人遣返航班上71人呈阳性 | 99国产视频| 丰满女朋友在线观看中文 | 好紧的小嫩嫩17p | 折磨比基尼美女挠肚子 | 国产情侣真实露脸在线 | 天天操狠狠操夜夜操 | 色中色入口2015 | 绞尽奶汁by菊花开 | 蜜臀AV人妻久久无码精品麻豆 | black大战chinese周晓琳 | 好吊日视频在线 | 在线 无码 中文 强 乱 | 日本无码色哟哟婷婷最新网站 | 久久久无码精品亚洲A片软件 | 狠狠躁日日躁人人爽 | 國產麻豆AVMDXMDX | 国产小视频免费看 | 公粗挺进了我的密道在线播放贝壳 | 亚洲 自拍 清纯 综合图区 | 日韩视频中文在线一区 | 国产精品久久人妻无码网站一区L | 亚洲大片免费 | 日本久久高清视频 | 亚洲 欧美 日韩 精品 自拍 | 亚洲熟妇无码乱子AV电影 | 国语92电影网午夜福利 | 一个人日本的视频免费完整版 | 精品久久久久久久久免费影院 | 色久天 | 国产在线精品国自产拍影院午夜 | 一本色道久久综合亚洲精品蜜桃冫 | 狠狠操天天操夜夜操 | 人人爽天天碰狠狠添 | 美女内射少妇一区二区四区 | 久久综合给合久久狠狠狠… | 2020国产成人免费视频 |