首页 > 编程 > .NET > 正文

带你走进ASP.NET(3)

2024-07-10 12:55:56
字体:
来源:转载
供稿:网友
1.2.2内容和代码分离
   现在的网站建设通常要求开发人员做后台的程序设计,前面有专业的美工做界面设计。虽然有时候开发人员也会做些界面设计,但是通常都无法达到专业的要求。上面说过,在以前的asp中,由于代码和html页面语言混杂在一起,这就使得网站的建设变得相当的困难。在asp.net中,微软使用代码后置很好的解决了这个问题。
   我们现在建立一个html页面,如下:
  <%@ page language="c#" codebehind="webform1.aspx.cs"
   autoeventwireup="false" inherits="aspcool.webform1" %>
  <!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
  <html>
   <head>
   <title>webform1</title>
   <meta name="generator" content="microsoft visual studio 7.0">
   <meta name="code_language" content="c#">
   <meta name="vs_defaultclientscript" content="javascript">
   <meta name="vs_targetschema" content="http://schemas.microsoft.com/intellisense/ie5">
   </head>
   <body ms_positioning="gridlayout">
   <form id="form1" method="post" runat="server">
   <font face="宋体">
   <asp:textbox id="textbox1" runat="server"></asp:textbox>
   <asp:button id="button1" runat="server" text="button"></asp:button></font>
   </form>
   </body>
  
  
  从第一行中我们可以看出,该页面的后台代码全都在webform1.aspx.cs文件中。我们可以在这个文件中编写程序,如下所示:
  using system;
  using system.collections;
  using system.componentmodel;
  using system.data;
  using system.drawing;
  using system.web;
  using system.web.sessionstate;
  using system.web.ui;
  using system.web.ui.webcontrols;
  using system.web.ui.htmlcontrols;
  
  namespace aspcool
  {
   /// <summary>
   /// summary description for webform1.
   /// </summary>
   public class webform1 : system.web.ui.page
   {
   protected system.web.ui.webcontrols.textbox textbox1;
   protected system.web.ui.webcontrols.button button1;
  
   private void page_load(object sender, system.eventargs e)
   {
   // put user code to initialize the page here
   }
  
   #region web form designer generated code
   override protected void oninit(eventargs e)
   {
   //
   // codegen: this call is required by the asp.net web form designer.
   //
   initializecomponent();
   base.oninit(e);
   }
  
   /// <summary>
   /// required method for designer support - do not modify
   /// the contents of this method with the code editor.
   /// </summary>
   private void initializecomponent()
   {
   this.button1.click += new system.eventhandler(this.button1_click);
   this.load += new system.eventhandler(this.page_load);
  
   }
   #endregion
  
   private void button1_click(object sender, system.eventargs e)
   {
  
   }
   }
  }
  通过代码后置,开发人员可以直接修改.cs文件(在visual basic.net中是.vb文件)。而页面设计人员可以修改html页面,这样就大大简化了网站的建设过程。
  1.2.3 asp.net丰富的web控件
   asp.net的另外一个优点就是给我们提供了大量的丰富的web控件。你可以在system.web.ui.webcontrols名字空间下找到各种各样的web控件,这些控件中包括运行在服务端的from控件,例如:button、textbox等,同时也包括一些特殊用途的控件,如:广告轮换控件、日历控件,以及用户验证控件等。下面我们就具几个例子来看看如何使用这些控件。
  
  1. 广告轮换控件<asp:adrotator>
  广告轮换控件可以在网页上显示旋转的广告。广告链接信息保存在一个xml文件中,如ads.xml。
  
  <?xml version="1.0" encoding="utf-8" ?>
  <advertisements>
  
   <ad>
   <imageurl>http://www.aspcool.com/images/newaspcool.gif</imageurl>
   <navigateurl>http://www.aspcool.com</navigateurl>
   <alternatetext>alt text</alternatetext>
   <keyword>computers</keyword>
   <impressions>80</impressions>
   </ad>
  
   <ad>
   <imageurl>http://www.aspcool.com/images/chat.gif</imageurl>
   <navigateurl>http://www.chaxiu.com</navigateurl>
   <alternatetext>alt text</alternatetext>
   <keyword>computers</keyword>
   <impressions>80</impressions>
   </ad>
  </advertisements>
  
  我们现在在asp.net 页面中加上一个<asp:adrotator>,如下所示:
  <html>
   <head>
   <title>广告轮换程序</title>
   </head>
   <body ms_positioning="gridlayout">
   <form id="form1" method="post" runat="server">
   <asp:adrotator id="adrotator1" runat="server" width="468px" height="60px" advertisementfile="ads.xml"></asp:adrotator>
   </form>
   </body>
  </html>
  运行此程序,你就会得到一个旋转显示广告的页面了。
  
  2. 日历控件<asp:calendar>
  使用日历控件,我们可以很快生成一个日历的web页面。代码如下:
  <html>
   <head>
   <title>广告轮换程序</title>
   </head>
   <body ms_positioning="gridlayout">
   <form id="form1" method="post" runat="server">
   <asp:calendar id="calendar1" runat="server"></asp:calendar>
   </form>
   </body>
  </html>
  在visual studio.net中,你直接从工具栏中拖过来就可以使用了。
  
  3. 验证控件
  以前我们我们通过自己写javascript脚本来验证用户输入的信息。在asp.net中,只要我们使用验证控件这些代码也会自动生成。它能够向用户提示输入的错误信息。下面我就给大家列出这些验证控件:
  
  
  控件名称 说明
  requiredfieldvalidator 确保用户不跳过输入。
  comparevalidator 使用比较运算符(小于、等于、大于等)将用户的输入与另一控件的常数值或属性值进行比较。
  rangevalidator 检查用户的输入是否在指定的上下边界之间。 可以检查数字、字母或日期对内的范围。可以将边界表示为常数。
  regularexpressionvalidator 检查输入是否与正则表达式定义的模式匹配。该验证类型允许检查可预知的字符序列,如社会保障号、电子邮件地址、电话号码、邮政编码等中的字符序列。
  customvalidator 使用您自己编写的验证逻辑检查用户的输入。该验证类型允许检查运行时导出的值。
  validationsummary 以摘要的形式显示页上所有验证程序的验证错误。
  
  
  
  好了,既然asp.net有如此多的优点,让我们现在就开始安装和使用asp.net吧!
国内最大的酷站演示中心!
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表