ASP.NET Forms
Transcription
ASP.NET Forms
ASP.NET Forms • An ASP.NET form is a HTML form plus asp.net code in the form of server controls. • ASP.NET form has extra functionality to maintain form data or state (_VIEWSTATE plus POSTBACK) eg text in a text box – Hidden variable to store ‘coded’ version of the form • ASP.NET server controls duplicate the functionality of many HTML elements. – Take the form of an html-like tag, marking the point in the page where the server needs to generate corresponding true HTML elements. (produces server side object that can be manipulated at any part of the code.) Example: datacontrol2.aspx <%@ Page language="VB" runat="server" %> <%@ Import namespace="System.Data" %> <%@ Import namespace="System.XML" %> <script language="vb" runat="server"> Sub Page_Load() Dim xmlFilename As String xmlFilename= "C:\cse2030\jason1\artists.xml" Dim newDataSet As New DataSet newDataSet.ReadXML(xmlFilename) DataGrid1.DataSource = newDataSet DataGrid1.DataBind() End Sub </script> <html> <head> <title>Data Grid Control example</title> </head> <body> <asp:DataGrid id="DataGrid1" runat="server" /> </body> </html> Artists.xml <?xml version="1.0"?> <artist> <item> <name>Vincent Van Gogh</name> <nationality>Dutch</nationality> <movement>Post Impressionism </movement> <birthdate>30th March 1853</birthdate> </item> <item> <name>Paul Klee </name> <nationality>Swiss </nationality> <movement>Abstract Expressionism </movement> <birthdate>18th December 1879</birthdate> </item> <item> <name>Max Ernst </name> <nationality>German </nationality> <movement>Surrealism </movement> <birthdate>2nd April 1891</birthdate> </item> </artist> ASP.NET execution • When a browser requests a web page, server locates the page. If it has an .aspx extension, then the server sends it to aspnet_isapi.dll which forwards it to the CLR. The CLR compiles the code (if it is a new page) and executes it to produce html that is sent to the client. • All the ASP.NET code can be in a separate file, know as a code-behind page. – quickstart-aspforms-example13 Web Forms • • • • • • Server side controls Generate output suitable for the browser Preserves state across page refreshes (Viewstate) Raise server side events Used as the base to build richer controls ASP.Net includes a range of useful classes and namespaces – Namespace is like a class library eg. System.Web.UI.HtmlControls – See class browser from last lecture What are Server Controls? • Server programmable objects – have properties,events,methods that can be accessed at run time (Use Visual Studio.Net at design time) System.Web.UI.WebControls namespace • denoted by Tag with the runat=“server” attribute • render different HTML to support multiple browser types (eg IE4 and above -rendering implemented on the client; IE3 done by the server) • Can create server control from HTML control by adding the runat=“server” attribute – eg <input type=“text” runat=“server”> Server Side Controls • HTMLControls – System.Web.UI.HtmlControls namespace – Can be directly mapped to HTML tags – Used for backward compatibility with ASP eg <input type=“text” runat=“server” id=“txtname” value=“mytext” > • Web Controls – System.Web.UI.WebControls namespace – Form based event model eg buttonclick – Offer a richer set of controls • implement a number of common properties (properties through class browser) • data binding • automatic browser detection <asp:textbox id=“txtname” runat=“server” text=“mytext”> • Programmatic reference of a control is by the unique id attribute eg id=“txtname” How do server controls work? • Declared with the runat=“server” attribute • when the aspx page is executed – creates Action and Method attributes of the form – adds unique Id and Name attributes to controls – adds Value attribute to controls – adds a hidden control (_VIEWSTATE) to the form to save form state information Server control example <script runat="server" language="vb"> Sub Page_Load() if Request.Form("list1") <> "" then Message.text = "You have selected " + Request.Form("list1") end if End Sub </script> <html> <head> <title>Drop Down List Example</title> </head> <body> <asp:label id="message" runat="server"/> <br /> <form runat="server"> <!– notice no action or method attributes --> Which city do you wish to look at hotels for?<br /><br /> <asp:dropdownlist id="list1" runat="server"> <asp:listitem>Madrid</asp:listitem> <asp:listitem>Oslo</asp:listitem> <asp:listitem>Lisbon</asp:listitem> </asp:dropdownlist> <br /><br /><br /><br /> <input type="Submit"> </form> </body> </html> Server control example cont 2. Server control example cont 3. Server control eg. Cont. 4 – view source. <html> <head> <title>Drop Down List Example</title> </head> <body> <span id="message">You have selected Lisbon</span> <br /> <form name="_ctl0" method="post" action="listpage.aspx" id="_ctl0"> <input type="hidden" name="__VIEWSTATE" value="dDwtMTMyNTU5Mzc0Njt0PDtsPGk8MT47PjtsPHQ8cDxwPGw8VGV4dDs+ O2w8WW91IGhhdmUgc2VsZWN0ZWQgTGlzYm9uOz4+Oz47Oz47Pj47PtM3XxNyv 4v6En+WgxP4D5/iJj1M" /> Which city do you wish to look at hotels for?<br /><br /> <select name="list1" id="list1"> <option value="Madrid">Madrid</option> <option value="Oslo">Oslo</option> <option selected="selected" value="Lisbon">Lisbon</option> </select> <br /><br /><br /><br /> <input type="Submit"> </form> </body> </html> Server control eg. Cont. 5 - Notes • All output from server to browser is HTML • New attributes added to form tag – – – – <form name="_ctl0" method="post" action="listpage.aspx" id="_ctl0"> Post is the asp.net default method Action attribute points to the same page (listpage.aspx) A hidden control stores the state of the page <input type="hidden" name="__VIEWSTATE" value="dDwtMTMyNTU5Mzc0Njt0PDtsPGk8MT47PjtsPHQ8cDxwPGw8VGV4dDs+ O2w8WW91IGhhdmUgc2VsZWN0ZWQgTGlzYm9uOz4+Oz47Oz47Pj47PtM3XxNyv 4v6En+WgxP4D5/iJj1M" /> – Used by asp.net to keep track of all server control settings from one page refresh to another; otherwise listbox would revert to static default setting every time page is loaded. Very useful for data validation. HTML controls demo – demo server_controls.aspx (note form state is lost; cf: server_controlsM.aspx – same controls but with runat=“server”) <%@ Page Language="vb" %> <HTML> <body> <form> Name: <input type="text"> <P> Profession: <select> <option>Software Engineer</option> <option>Software Tester</option> <option>Program Manager</option> </select> <p> <input type="submit" value="Save"> </form> </body> </html> Web Controls • There are five types of controls – – – – – Intrinsic Controls eg asp:list, asp:button etc List Controls eg asp:datagrid, asp:datarepeater Rich Controls eg asp:calander Validation Controls eg asp:rangeValidator Custom Controls – user defined • They support properties, methods and events • System.Web.UI.WebControls namespace Intrinsic Controls • Executed on the server side • Accessed via properties/attributes – (some common to all controls eg text, backcolor and other specific eg checked=true for a checkbox) • • • • Have associated events Can maintain state information. Output is standard HTML Prefixed with the tag ‘asp’ (cf. HTML controls don’t have this tag) Intrinsic Controls (2) HTML Output ASP.NET Intrinsic Controls <select>…</select> <asp:DropDownList> <td>…</td> <asp:TableCell> <tr>…</tr> <asp:TableRow> <table>…</table> <asp:Table> <div>…</div> <asp:Panel> <span>…</span> <asp:Label> <img src=“…”> <asp:Image> <select size=“…”>…</select> <asp:ListBox> <input type=“radio”> <asp:RadioButton> <input type=“checkbox”> <asp:CheckBox> <input type=“text” value=“…”> <asp:TextBox> <a href=“…”>…</a> <asp:HyperLink> <input type=“image”> <asp:ImageButton> <a href=“jscript:__doPostBack(…)”>…</a> <asp:LinkButton> <input type=“submit”> <asp:Button> Intrinsic Controls (3) Sample Server Side Code <asp:ListBox runat=“server”> <asp:ListItem>Test1</asp:ListItem> <asp:ListItem>Test3</asp:ListItem> </asp:ListBox> Sample Client Side Result <select name=ListBox0> <option value=“Test1”>Test1</option> <option value=“Test3”>Test3</option> </select> Two syntax forms: <asp:label id=“message1” forecolor=“red” runat=“server”> Hello </asp:label> Is the same as <asp:label id=“message1” forecolor=“red” runat=“server” text=“Hello”/> List Controls • Displaying lists of data. • Also supports additional functionality, including sorting, filtering, selecting items. • Five types (next lecture; datacontrol2.aspx-slide 2) – Repeater – Just renders a repeated list – DataList – Like Repeater but with additional formatting functionality – DataGrid – Produces data in a Grid format, but also provides functionality for data editing. – RadioButtonList – Renders the list with RadioButtons associated with each data item. – CheckboxList – Renders the list with CheckBoxes associated with each data item. (Discuss next lecture) Rich Controls • Ever growing list of Rich Controls • EG. – Calendar – TreeView – ImageGenerator – AdRotator – Etc (Discuss next lecture) Validation Controls • One of the common tasks of scripts has been validating data entered on the web page • ASP.NET simplifies validation via a number of controls (can be either client or server based; can have more than one for a control; triggered by events eg textchange) – – – – – RequiredFieldValidator CompareValidator RangeValidator RegularExpressionValidator CustomValidator Web Control Events • Each web control has a number of events (onClick…etc) • There are events associated with server events (Page_load..etc) • Each event results in a reload of the page via a postback • A web control is associated to an event by setting its attributes - the name of the function which implements the event handler. HTML Control Server Event Handlers • Client-side controls have events such as onClick and onChange are associated with HTML client controls – To be able to detect these events on the server, Visual Studio .NET will create a generic JavaScript event handler called _doPostBack – The event sends the name of the control (eventTarget) and any arguments (eventArgument) back to the server when the event is intercepted – This handler only is required once per page, and is written by the server, not the programmer • OnServerChange event occurs when an HTML server control value has changed Sample Web Form <input name="WebAddress" type="text" id="WebAddress" onchange="__doPostBack('WebAddress','')" language="javascript" /> <input type="submit" name="GoBtn" value="Go" id="GoBtn" /> <input type="hidden" name="__EVENTTARGET" value="" /> <input type="hidden" name="__EVENTARGUMENT" value="" /> Sample _doPostback Event Handler <script language="javascript"> <!-function __doPostBack(eventTarget, eventArgument) { var theform = document.ctrl0; theform.__EVENTTARGET.value = eventTarget; theform.__EVENTARGUMENT.value = eventArgument; theform.submit(); } // --> </script> Page event life cycle • In ASP.NET a structured set of events occurs every time a page is viewed. The order is: – Page_init (done once; useful for variable initialisation) – Page_load (can be used to load data into controls from server DB) see POSTBACK – Change events eg textbox1_changed; by default only click events submit form to the server; change events are queued till then. (Some controls have an AUTOPOSTBACK property which will force a post) – Click event eg button1_click – Page_Unload (last event before page is discarded eg user going to another page; useful for closing files, db’s etc Event example <%@ Page Language="vb" %> <HTML> <body> <SCRIPT language="VB" runat="Server"> Sub GreetMe(s As Object, e As EventArgs) label1.Text = "Hello " & txtName.Value & _ ". I see your occupation is " & lstTitle.Value End Sub </SCRIPT> <FORM runat="server"> Name: <INPUT type="text" id="txtName" runat="server"> <p>Profession: <SELECT id="lstTitle" runat="server"> <OPTION> Software Engineer </OPTION> <OPTION> Software Tester </OPTION> <OPTION> Program Manager </OPTION> </SELECT> <p><INPUT type="Submit" Value="Save" onServerClick="GreetMe" runat="server"> <p><asp:label id="label1" runat="server"/> </FORM> </body> </html> Event example cont. What is PostBack? • A PostBack is as result of a event within the ASP.NET being triggered. This is opposed to a page request. • Using Page.IsPostBack you can determine whether the event is as a result of a Web Control event or a request for the page. • Since Web Controls implement ViewState (A Web Control remembers content regardless of the number of refreshes), there is no need to requery a database, just to populate controls. • PostBack offers the ability to only execute code that is required, not the entire ASP+ script. Postback example <%@ Page Language="vb" %> <HTML> <body> <SCRIPT language="VB" runat="Server"> Sub GreetMe(s As Object, e As EventArgs) label1.Text = "Hello " & txtName.Value & _ ". I see your occupation is " & lstTitle.Value End Sub Sub Page_Load(s As Object, e As EventArgs) If Not Page.IsPostBack Then txtName.Value = "Enter your name" End If End Sub </SCRIPT> <FORM runat="server"> Name: <INPUT type="text" id="txtName" runat="server"> <p>Profession: <SELECT id="lstTitle" runat="server"> <OPTION> Software Engineer </OPTION> <OPTION> Software Tester </OPTION> <OPTION> Program Manager </OPTION> </SELECT> <p><INPUT type="Submit" Value="Save" onServerClick="GreetMe" runat="server"> <p><asp:label id="label1" runat="server"/> </FORM> </body> </html> Another example-holidaypage.aspx. <html> <head> <title>Holiday page</title> </head> <body> <form action="holidayresponse.aspx" method="post"> <h1>Feiertag Holidays</h1> Please enter your details here. <br /><br /> Name:<asp:textbox id="FullName" runat="server" /> <br /><br /> Address:<asp:textbox id="Address" rows="5" textmode="multiline" runat="server" /> <br /><br /> Sex <asp:radiobuttonlist id="sex" runat="server"> <asp:listitem value="Male" /> <asp:listitem value="Female" /> </asp:radiobuttonlist> Please select the destination you would like details on: <asp:dropdownlist id="Destination" runat="server"> <asp:listitem value="Madrid" /> <asp:listitem value="Barcelona"/> <asp:listitem value="Lisbon"/> <asp:listitem value="Oslo"/> <asp:listitem value="Prague"/> Please enter your details here. </asp:dropdownlist> <br /><br /> <br /><br /> Name:<input type="text" id="FullName" <input type="Submit"> runat="server" /> <input type="Reset"> <br /><br /> </form> </body> </html> This will not work because <asp:..> don’t work unless they are in the form with runat=“server”. But this stops us using a different form action. Use HTML controls instead. Another eg. cont 1-holidayresponse.aspx. <script runat="server" language="vb"> Sub Page_Load() Response.Write ("<b>Name:</b> " + Request.Form("FullName") + "<br />") Response.Write ("<b>Address:</b> " + Request.Form("Address") + "<br />") Response.Write ("<b>Sex:</b> " + Request.Form("Sex") + "<br />") Response.Write ("<b>Destination:</b> " + Request.Form("Destination") + "<br />") End Sub </script> <html> <head> <title>Holiday page</title> </head> <body> <br /><br /> These details have been entered into our database, you should receive a confirmation email from us shortly. <br /><br /> </body> </html> Validation controls revisited • Properties of the validation control – Control to validate (id of control) – Error message – Display (static or dynamic as to where the error message is displayed) Name: <asp:textbox id="txtName" runat="server" /> …… <asp:RequiredFieldValidator id="txtNameValidator" runat="server" controlToValidate="txtName" errorMessage="You must enter your name" display="dynamic"> </asp:RequiredFieldValidator> Validation Control eg1.validation.aspx <%@ Page language="vb" %> <HTML> <body> <SCRIPT language="VB" runat="Server"> Sub submit(s As Object, e As EventArgs) spnOutputButton.InnerHTML = "Button clicked. Textbox value is " & txtName.Text End Sub Sub lst_change(s As Object, e As EventArgs) spnOutputList.InnerHTML = "Listbox changed to " & lstTitle.SelectedItem.Value End Sub Sub Page_load(s As Object, e As EventArgs) lblListbox.DataBind() End Sub </SCRIPT> Validation Control example 2. <FORM runat="server"> Name: <asp:textbox id="txtName" runat="server" /> <asp:RequiredFieldValidator id="txtNameValidator" runat="server" controlToValidate="txtName" errorMessage="You must enter your name" display="dynamic"> </asp:RequiredFieldValidator> <asp:RangeValidator id="txtNameRngValidator" runat="server" controlToValidate="txtName" errorMessage="Please enter a name that begins with 'A'" type="String" minimumValue="A" maximumValue="B" display="dynamic"> </asp:RangeValidator> Validation Control example 3. <p>Profession: <asp:dropdownlist autopostback=True id="lstTitle" onselectedindexchanged="lst_change" runat="server" > <asp:listitem>Program Manager</asp:listitem> <asp:listitem>Tester</asp:listitem> <asp:listitem>User Assistance</asp:listitem> </asp:dropdownlist> <p><asp:Button Text="Save" onclick="submit" runat="server" ID=Button1/> <asp:label id="lblListbox" runat=Server text="<%# lstTitle.selecteditem.text %>" /> <p><span style="color:red;" id="spnOutputList" runat="server"></span> <p><span style="color:red;" id="spnOutputButton" runat="server"></span> </form> </body> </html> <HTML> <body> <form name="_ctl0" method="post" action="validation.aspx" language="javascript" onsubmit="ValidatorOnSubmit();" id="_ctl0"> …. <script language="javascript"> <!-function __doPostBack(eventTarget, eventArgument) { var theform = document._ctl0; theform.__EVENTTARGET.value = eventTarget; theform.__EVENTARGUMENT.value = eventArgument; theform.submit(); } // --> </script> Code Behind • Allows for the separation of server side code and HTML • Create a class file that inherits from ASP.NET Page class – Done automatically by VS.NET User Controls • Can be used to write ‘include files’ to create consistent look and feel • End with .ascx • Included with <%@ Register TagPrefix="UserControl" TagName="Header" Src="header.ascx" %> • Used with <UserControl:Header id="MyHeader" runat="Server" /> • TagPrefix and TagName • See example source usercontroleg.txt • Demo Configuration and Deployment • Configuration details are in a text file called web.config that is structured in XML format. This is in the site’s root folder • All files that a Web application needs are in folder under the site’s root folder and DLL’s are in the /bin folder (don’t have to register in the Registry; only need to copy) /wwwroot /webapplication1 - aspx, web.config /bin - dll’s /webapplication2 - aspx, web.config /bin - dll’s