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

一步一步學Silverlight :數據與通信之WebClient

概述

Silverlight 2 Beta 1版本發布了,無論從Runtime還是Tools都給我們帶來了很多的驚喜,如支持框架語言Visual Basic, Visual C#, IronRuby, IronPython,對JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步學Silverlight 2系列》文章帶您快速進入Silverlight 2開發。

本文將介紹如何在Silverlight 2中使用Web Client進行通信。

簡單示例

編寫一個簡單的示例,在該示例中,選擇一本書籍之后,我們通過Web Client去查詢書籍的價格,并顯示出來,最終的效果如下:

TerryLee_Silverlight2_0059

編寫界面布局,XAML如下:

<Grid Background="#46461F">    <Grid.RowDefinitions>        <RowDefinition Height="40"></RowDefinition>        <RowDefinition Height="*"></RowDefinition>        <RowDefinition Height="40"></RowDefinition>    </Grid.RowDefinitions>    <Grid.ColumnDefinitions>        <ColumnDefinition></ColumnDefinition>    </Grid.ColumnDefinitions>    <Border Grid.Row="0" Grid.Column="0" CornerRadius="15"            Width="240" Height="36"            Margin="20 0 0 0" HorizontalAlignment="Left">        <TextBlock Text="書籍列表" Foreground="White"                   HorizontalAlignment="Left" VerticalAlignment="Center"                   Margin="20 0 0 0"></TextBlock>    </Border>    <ListBox x:Name="Books" Grid.Row="1" Margin="40 10 10 10"             SelectionChanged="Books_SelectionChanged">        <ListBox.ItemTemplate>            <DataTemplate>                <StackPanel>                    <TextBlock Text="{Binding Name}" Height="32"></TextBlock>                </StackPanel>            </DataTemplate>        </ListBox.ItemTemplate>    </ListBox>    <Border Grid.Row="2" Grid.Column="0" CornerRadius="15"            Width="240" Height="36" Background="Orange"            Margin="20 0 0 0" HorizontalAlignment="Left">        <TextBlock x:Name="lblPrice" Text="價格:" Foreground="White"                   HorizontalAlignment="Left" VerticalAlignment="Center"                   Margin="20 0 0 0"></TextBlock>    </Border></Grid>

為了模擬查詢價格,我們編寫一個HttpHandler,接收書籍的No,并返回價格:

public class BookHandler : IHttpHandler{    public static readonly string[] PriceList = new string[] {         "66.00",        "78.30",        "56.50",        "28.80",        "77.00"    };    public void ProcessRequest(HttpContext context)    {        context.Response.ContentType = "text/plain";        context.Response.Write(PriceList[Int32.Parse(context.Request.QueryString["No"])]);    }    public bool IsReusable    {        get        {            return false;        }    }}

在界面加載時綁定書籍列表,關于數據綁定可以參考一步一步學Silverlight 2系列(11):數據綁定

void UserControl_Loaded(object sender, RoutedEventArgs e){    List<Book> books = new List<Book>() {         new Book("Professional ASP.NET 3.5"),        new Book("ASP.NET AJAX In Action"),        new Book("Silverlight In Action"),        new Book("ASP.NET 3.5 Unleashed"),        new Book("Introducing Microsoft ASP.NET AJAX")    };    Books.ItemsSource = books;}

接下來當用戶選擇一本書籍時,需要通過Web Client去獲取書籍的價格,在Silverlight 2中,所有的網絡通信API都設計為了異步模式。在聲明一個Web Client實例后,我們需要為它注冊DownloadStringCompleted事件處理方法,在下載完成后將會被回調,然后再調用DownloadStringAsync方法開始下載。

void Books_SelectionChanged(object sender, SelectionChangedEventArgs e){    Uri endpoint = new Uri(String.Format("http://localhost:49955/BookHandler.ashx?No={0}",Books.SelectedIndex));    WebClient client = new WebClient();    client.DownloadStringCompleted += new DownloadStringCompletedEventHandler(client_DownloadStringCompleted);    client.DownloadStringAsync(endpoint);}void client_DownloadStringCompleted(object sender, DownloadStringCompletedEventArgs e){    if (e.Error == null)    {        lblPrice.Text = "價格:" + e.Result;    }    else    {        lblPrice.Text = e.Error.Message;    }}

 

 

注意大家可以在Web Application Project的屬性頁中,把ASP.NET Development Server的端口號設置為一個固定的端口號:

TerryLee_Silverlight2_0060

最后完整的代碼如下:

public partial class Page : UserControl{    public Page()    {        InitializeComponent();    }    void UserControl_Loaded(object sender, RoutedEventArgs e)    {        List<Book> books = new List<Book>() {             new Book("Professional ASP.NET 3.5"),            new Book("ASP.NET AJAX In Action"),            new Book("Silverlight In Action"),            new Book("ASP.NET 3.5 Unleashed"),            new Book("Introducing Microsoft ASP.NET AJAX")        };        Books.ItemsSource = books;    }    void Books_SelectionChanged(object sender, SelectionChangedEventArgs e)    {        Uri endpoint = new Uri(String.Format("http://localhost:49955/BookHandler.ashx?No={0}",Books.SelectedIndex));        WebClient client = new WebClient();        client.DownloadStringCompleted += new DownloadStringCompletedEventHandler(client_DownloadStringCompleted);        client.DownloadStringAsync(endpoint);    }    void client_DownloadStringCompleted(object sender, DownloadStringCompletedEventArgs e)    {        if (e.Error == null)        {            lblPrice.Text = "價格:" + e.Result;        }        else        {            lblPrice.Text = e.Error.Message;        }    }}

運行后效果如下:

TerryLee_Silverlight2_0059

當我們選擇其中一本書籍時,將會顯示出它的價格:

TerryLee_Silverlight2_0061

結束語

本文簡單介紹了Silverlight 2中使用Web Client進行通信的知識,在Silverlight 2中,提供的通信API非常豐富,后面將會介紹其他的方式。你可以從這里下載本文示例代碼。

NET技術一步一步學Silverlight :數據與通信之WebClient,轉載需保留來源!

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

主站蜘蛛池模板: 久久99re6热在线播放 | av在线色| 99视频免费在线观看 | FREEHDXXXX学生妹 | 97一期涩涩97片久久久久久久 | 国产一级做a爰片久久毛片男 | 久久中文字幕亚洲 | 樱桃视频高清免费观看在线播放 | 2019午夜福利757视频第12集 | 啪啪漫画无遮挡全彩h网站 啪啪漫画无遮挡全彩h同人 | 亚洲香蕉网久久综合影院 | 十分钟免费观看高清视频大全 | 亚洲精品视频区 | 中文字AV字幕在线观看 | 久久精品国产欧美成人 | 亚洲午夜精品A片久久软件 亚洲午夜精品A片久久不卡蜜桃 | 扒开老师大腿猛进AAA片 | 黑人强伦姧人妻日韩那庞大的 | 三级黄色在线视频中文 | 小夫妻天天恶战 | 国产麻豆91网在线看 | 国产成年人在线观看 | 国产成人 免费观看 | 国产精品一区二区在线播放 | 亚洲中文 字幕 国产 综合 | 欧美乱码卡一卡二卡四卡免费 | 国产亚洲日韩另类在线观看 | 亚洲免费视频在线观看 | 擦擦擦在线视频观看 | 免费看毛片的网址 | 51国产偷自视频在线视频播放 | 亚洲一二三产品区别在哪里 | 精品一成人岛国片在线观看 | 豆奶视频在线高清观看 | 俄罗斯破处 | 蜜桃臀无码内射一区二区三区 | 亚洲精品高清视频 | 无码任你躁久久久久久久 | 双性大乳浪受噗呲噗呲h总 双性被疯狂灌满精NP | 亚洲日韩成人 | 久久深夜视频 |