230 likes | 374 Views
"Atlas". AJAX Extensions til ASP.NET. "Atlas". "Atlas" er det interne navn for Microsoft's AJAX-produkter version 1.0 er udgivet i januar 2007 produktet hedder AJAX Extensions for ASP.NET Mål? Bedre brugeroplevelser Større funktionalitet på klient-siden
E N D
"Atlas" • AJAX Extensions til ASP.NET
"Atlas" • "Atlas" er det interne navn for Microsoft's AJAX-produkter • version 1.0 er udgivet i januar 2007 • produktet hedder AJAX Extensions for ASP.NET • Mål? • Bedre brugeroplevelser • Større funktionalitet på klient-siden • Forbedret intergration af web-tjenester på klient-siden • en brugeroplevelse, som ligger tættere opad Windows-applikationer!
Hvad er Atlas? • Atlas = Værktøjer til AJAX-applikationer • 3 væsentlige komponenter: • Klient-side kontroller & JavaScript-biblioteker • Microsoft AJAX Library • Server-side ASP.NET AJAX-kontroller • ASP.NET 2.0 AJAX Extensions • Udvidet samling af AJAX-kontroller • ASP.NET AJAX Control Toolkit
ASP .NET 2.0 Page Frameworks Server Controls Application Services Atlas - arkitektur Atlas Client Framework Atlas Server Framework Controls & Components Atlas Server Controls App Services Bridge Component Model Web Services Bridge UI Framework Base Class Library Script Core Browser Compatibility Server Klient – Browser
Microsoft AJAX Library • Klient-side-kontroller og JavaScript-biblioteker
Microsoft AJAX Library Atlas Client Framework Controls & Components Component Model UI Framework • Kompatibilitet på tværs af browsere • IE, Firefox, Opera, ... • Script run-time-kerne med JavaScript-tilføjelser • Klasser, namespaces, arv, interfaces • hjælp-klasser til .NET (fx StringBuilder) • Komponentmodel og UI Framework • Klient-side-kontroller, som mapper DHTML elements • XML-script-erklæringer, data-binding, validering • Adfærd: træk-og-slip, værktøjstips, auto-komplettering Base Class Library Script Core Browser Compatibility
Eksempel • Atlas-baseret web-applikation, som viser aktuelle klokkeslæt • anvender Microsoft's AJAX library på klienten • anvender VB-agtig timer-kontrol til at hente klokkeslættet • foretager asynkront kald til en webtjeneste (mere effektivt end kald til en side) GetTime.aspx Web-server TimeSvc.asmx <result> 03:45:23 PM</result>
TimeSvc.asmx Web-server TimeSvc.asmx • TimeSvc.asmx er en webtjeneste (ASP.NET modul) • indeholder ingen UI, kald til GetTime( ) returnerer aktuelle klokkeslæt … TimeSvc.asmx <%@ WebService Language="C#"CodeBehind="~/App_Code/TimeSvc.cs"Class="TimeSvc"%> TimeSvc.cs [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] public class TimeSvc : System.Web.Services.WebService { [WebMethod] public string GetTime() { return DateTime.Now.ToString("hh:mm:ss tt"); } }
GetTime.aspx • GetTime.aspx er en webside, som brugeren kan interagere med • anvender kontroller i AJAX –biblioteket for at blive browserusafhængig • Gør brug af en webtjeneste GetTime.aspx <head> <script type="text/javascript"> function pageLoad() { // create controls for page: var btn = new Sys.UI.Button($("cmdGetTime")); btn.click.add(OnGetTimeClick); btn.initialize(); } </script> </head> <body> <atlas:ScriptManager ...> <Services> <atlas:ServiceReference Path="TimeSvc.asmx" .../> </Services> </atlas:ScriptManager> <form>
Kald af webtjenesten • Ved knaptryk foretages det asynkrone kald • biblioteket opretter en proxy og håndterer detaljerne • når kaldet er færdigbehandlet, (evt. time-out), får vi tilbagemelding <script type="text/javascript" ...> function OnGetTimeClick(sender, args) { TimeSvc.GetTime(OnComplete, OnTimeout); } function OnComplete(result) { $("divTime").style.display = 'block'; lblTime.set_text(result); } function OnTimeout(result) { alert("Call to server failed, please try again in a few minutes."); }
Løbende opdatering • Anvendelse af timer til løbende opdatering • kontrollen findes i biblioteket… <script type="text/javascript" ...> . . . function OnEnableTimerClick(sender, args) { if (timerEnabled) return; var timer = new Sys.Timer(); timer.tick.add(OnGetTimeClick); timer.set_interval(3000); // 3 seconds timer.set_enabled(true); timerEnabled = true; }
Klient-side kontroller og adfær • Klientkontroller • Sys.UI.Window • Sys.UI.Label • Sys.UI.Image • Sys.UI.HyperLink • Sys.UI.Button • Sys.UI.CheckBox • Sys.UI.Select • Sys.UI.TextBox • Adfærd • Sys.UI.PopupBehavior • Sys.UI.ClickBehavior • Sys.UI.HoverBehavior • Sys.UI.AutoCompleteBehavior • Sys.UI.FloatingBehavior • Sys.UI.OpacityBehavior • Sys.UI.LayoutBehavior
ASP.NET 2.0 AJAX Extensions • AJAX-aktive server-side-kontroller til ASP.NET
Atlas Server Framework Atlas Server Controls App Services Bridge Web Services Bridge ASP.NET 2.0 AJAX Extensions • Tilbyder AJAX på en mere "ASP.NET-agtig" facon • server-side model • kræver intet klient-side JavaScript • ligner "Masterpage"-konceptet med placeholders , som håndterer alt arbejdet … • Alle de gode egenskaber ved AJAX uden klient-side programmering!
UpdatePanel • UpdatePanel–kontroller tilbyder AJAX-funktionalitet • en beholder, som gør det muligt at opdatere et område og foretage asynkrone kald • kontroller, som er placeret inde i en UpdatePanel -kontrol vil foretage et asynkront kald, ikke en postback • ingen speciel programmering på hverken klient eller server! Browser ASP .NET 2.0 ASPX side Postback- hændelsen udløses som sædvanligt! Asynkront Postback Hændelse udløses på panelet Kun “updatePanel”- området opdateres på klienten Indholdet af UpdatePanel-området returneres
Oprettelse af en AJAX-webapplikation • Opret et nyt websted af typen ASP.NET AJAX-enabled Web Site • den eneste forskel er web.config-filen • Byg webapplikationen ganske som du plejer … • træk og slip kontroller, master pages, osv. • placér kontroller på UpdatePanel-kontrollen, når du vil opnå AJAX-funktionalitet…
Eksempel • AJAX-opdatering af GridView fra en database…
Andre eksempler • Microsoft tilbyder en række demoapplikationer: • Simple List applikation • Contact List applikation • Multi-user Task List applikation
ASP.NET AJAX Control Toolkit • Yderligere AJAX-kontroller …
ASP.NET AJAX Control Toolkit • Yderligere AJAX-kontroller og udvidelser • software udviklingsværktøj (SDK) til at skrive AJAX-aktive komponenter til ASP.NET • fuld kildekode Accordion Animation CascadingDropDown CollapsiblePanel ConfirmButton DragPanel FilteredTextBox HoverMenu ModalPopup NumericUpDown PagingBulletedList PasswordStrength Rating Slider TextBoxWatermark ToggleButton UpdatePanelAnimation ...
Hvad så? • Øvelse #8 • Mere information om Atlas: • http://atlas.asp.net/
<blank> • …