打印本文 打印本文 关闭窗口 关闭窗口
从零开始学ASP.NET(基础篇)
作者:武汉SEO闵涛  文章来源:敏韬网  点击数4692  更新时间:2009/4/23 10:43:35  文章录入:mintao  责任编辑:mintao
            // 如果不符合日期格式即引发错误
            try
            {
                DateTime dt = new DateTime(year, month, date);
            }
            catch
            {
                labCheckInfo.Text = "输入的数字不符合日期格式";
                return;
            }

            labCheckInfo.Text = "输入正确";
        }


嗯,补充一下,关于StringBuider
在处理字符串的时候很多人喜欢+=,其实对于string来说,一旦定义了就无法更改了
所谓的+只是新建的一个新的string变量并赋值
所以对于尽量使用StringBuider的Append的方法,这样将大量的节省服务器的资源

第三天

学习目的:

  • 掌握下拉列表框的用法,并理解AutoPostBack属性;
  • 理解IsPoskBack及用法;
  • 初识DataTable的增加列、行,与下拉列表框绑定的方法。

    今天的内容稍多些,而且涉及一些比较常用的,如IsPostBack及DataTable的基本用法。

    知识点:
    IsPostBack:在页面onLoad之间是false值,而当从服务器回传后,该值变为true。当页面中的Button或ImageButton等触发事件,都会把表单回传到服务器,而返回时又会引发onLoad事件。为了节省服务器资源,有些加载中需进行一次,而不需要在回传后多次发生,可以用!IsPoskBack来作为条件,那么页面第一次加载后,以后就不会发生。该属性可以帮助你提高程序的性能。
    DataTable:即数据表,.Net 程序中最常用的类,特别是数据库开发中,没有该类的程序是不可想象的。

    先做个小程序来练练手,很简单,就一个下拉菜单,取名dlstWeb。在属性的Itmes选项中打开以下对话框,添加各项:


    图片如下:
    按Alt+滚轮缩放图片,单击查看完整图片

    ASPX中的代码为:
    <asp:DropDownList id="dlstWeb" style="Z-INDEX: 101; LEFT: 32px;
    POSITION: absolute; TOP: 32px" runat="server"
        Width="88px" AutoPostBack="True">
        <asp:ListItem value="http://www.sina.com.cn">新浪 </asp:ListItem>
        <asp:ListItem value="http://www.sohu.com">搜狐</asp:ListItem>
        <asp:ListItem value="http://www.163.com">网易</asp:ListItem>
    </asp:DropDownList>

    在下拉框的SelectedIndexChanged事件中的加入代码:
            private void dlstWeb_SelectedIndexChanged(object sender, System.EventArgs e)
            {
                Response.Write("<script language=javascript>window.open(''''" +dlstWeb.Selectedvalue + "'''');</script>");
            }

    按F5运行,可是我们发现这下拉框选择时什么事也没发生。原来原因是出在下拉框的AutoPostBack属性上,把它设为true后再试试,一切OK了。
    下面我们增加些难度,下拉框中的内容很多情况下不是事先固定的,而是要动态添加。这里设计是用一数据表DataTable与之联系起来。

    另建一文件,按上添加一下拉框,取名dlstWeb,先设AutoPostPack为false,否则在刚启动而面就触发SelectedIndexChanged事件,弹出窗口就乱飞了。
    在onLoad事件中添加代码,注意DataTable用法及IsPoskBack
    DataTable属于System.Data命名空间,所以如果页面没预添加,可以自行增加这一行。

            private void Page_Load(object sender, System.EventArgs e)
            {
                // 用IsPostBack判断,只在没有回传时才初始化
                // 这样可以防止每次刷新或回传时,都执行一次以下代码
                // 可以节省服务器的资源了。

                if (!IsPostBack)
                {
                    DataTable dt = new DataTable();
                    DataRow dr;

                    // 在表中增加字段
                    dt.Columns.Add("WebName", typeof(string));
                    dt.Columns.Add("WebUrl", typeof(string));

                    // 表中增加行
                    dr = dt.NewRow();
                    dr["WebName"] = "新浪";
                    dr["WebUrl"] = "http://www.sina.com.cn";
                    dt.Rows.Add(dr);

                    dr = dt.NewRow();
                    dr["WebName"] = "网易";
        

    上一页  [1] [2] [3] [4] [5] [6] [7]  下一页

  • 打印本文 打印本文 关闭窗口 关闭窗口