从零开始学ASP.NET :: 心随风起

来源: BlogBus 原始链接: http://mjm.blogbus.com:80/logs/2005/03/1067341.html 存档链接: https://web.archive.org/web/20060217052223id_/http://mjm.blogbus.com:80/logs/2005/03/1067341.html


心随风起 学习ASP.NET中的心得,与收集的一些资料 <<<ASP.NET提供文件下载函数 | 返回首页 | 刚刚整理好-汉字转拼音缩写的函数>>> 从零开始学ASP.NET 第一天 学习目的: 掌握最基本的Label、TextBox、Button控件用法 掌握用StringBuider类连接字符串 理解服务器的环境变量 StringBuilder类: 命名空间是:System.Text。 StringBuilder类是个高效的类,StringBuilder.Append连接字符串的方法是非常快的。用于连接大量的字符串,其速度的优越性就会体现出来。 先举几个例子: 在cs或vb文件的头部加上 [C#]using System.Text; [VB]Imports System.Text [C#]StringBuilder sbFirst = new StringBuilder(); sbFirst.Append(“这是第一个学ASPNET的例子”); sbFirst.Append( “这个例子太简单”); sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”); Response.Write(sbFirst.ToString()); [VB]Dim sbFirst As StringBuilder = New StringBuilder() sbFirst.Append(“这是第一个学ASPNET的例子”) sbFirst.Append( “这个例子太简单”) sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”) Response.Write(sbFirst.ToString) 下面就可以做正题了: 先建立一个C#的WEB应用程序工程,这废话我就少说了吧。 放一个Button控件:ID为btnShowVariable 放一个Label控件:ID为labServerVariable 添加Button的单击事件,如下代码 private void btnShowVariable_Click(object sender, System.EventArgs e) { labServerVariables.Text = ""; StringBuilder info = new StringBuilder(); foreach (object objVar in Request.ServerVariables) { info.Append(""); info.Append(objVar.ToString()); info.Append(" = "); info.Append(Request.ServerVariables[objVar.ToString()]); info.Append(""); } labServerVariables.Text = info.ToString(); } 结果显示: 图片如下: 这样我们就可以这样用 Response.Write(Request.ServerVariables["REMOTE_ADDR"]); // IP地址 Response.Write(""); Response.Write(Request.ServerVariables["URL"]); // 网页的URL 第二天 学习目的: 掌握文本框的用法 初次接触try…catch…语法 今天内容很轻松,用一个例子,输入年月日,判断输入是否正确 图片如下: 用个文本框,ID分别为txtYear,txtMonth,txtDate; 检验按钮的代码为: private void btnCheck_Click(object sender, System.EventArgs e) { int year, month, date; // 先把输入的字符转成int类型,如果非数字型, // 会触发错误 try { year = Convert.ToInt32(txtYear.Text); month = Convert.ToInt32(txtMonth.Text); date = Convert.ToInt32(txtDate.Text); } catch { labCheckInfo.Text = "输入的是非数字字符。"; return; } // 如果第一步检验合格,就把输入的数字转化为日期格式 // 如果不符合日期格式即引发错误 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选项中打开以下对话框,添加各项: 图片如下: 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("window.open('" +dlstWeb.Selectedvalue + "');"); } 按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"] = "网易"; dr["WebUrl"] = "http://www.163.com"; dt.Rows.Add(dr); dr = dt.NewRow(); dr["WebName"] = "搜狐"; dr["WebUrl"] = "http://www.sohu.com"; dt.Rows.Add(dr); // 把表与下拉菜单绑定数据 dlstWeb.DataSource = dt; dlstWeb.DataTextField = "WebName"; dlstWeb.DatavalueField = "WebUrl"; dlstWeb.DataBind(); // 开始时就把下拉菜单的AutoPostBack设为false, // 防止一开始就乱跳出网页来 dlstWeb.AutoPostBack = true; } } 下面的事件与前面一模一样了 private void dlstWeb_SelectedIndexChanged(object sender, System.EventArgs e) { Response.Write("window.open('" +dlstWeb.Selectedvalue + "');"); } 小结:今天的一些知识非常重要,为了理解,程序的难度并不高。但这是以后程序设计的基础,所以这些你一定要掌握。 VB.NET增加字段代码稍有不同,如下: // 在表中增加字段 dt.Columns.Add("WebName", GetType(String)) dt.Columns.Add("WebUrl", GetType(String)) 其它都差不多了。 每四天 学习目的: 学习ADO.NET用法,并如何用DataRearder读取数据 今天练习数据库的最基本用法,如何打开数据库。首先在网站设置文件web.config文件的下方加入以下节点: …… 该节点设置了数据库的路径,这样就可以很方便的调用数据库文件了,调用方法为: Server.MapPath(ConfigurationSettings.AppSettings["数据库1"]) 这是ASP.NET程序的通用方法,以后介绍的SQL SERVER数据库也是在此设置的。 好开始做程序,首先在CS文件的头部加入: using System.Configuration; using System.Data.OleDb; using System.Text; 以下在Page的Load事件中,读取ACCESS数据库,并用表格显示出来: private void Page_Load(object sender, System.EventArgs e) { StringBuilder sbTable = new StringBuilder(); // 用于输出表格的语句 string strConnection = "Provider=Microsoft.Jet.Oledb.4.0;Data Source="

  • Server.MapPath(ConfigurationSettings.AppSettings["数据库1"]); // 连接数据库的语句 OleDbConnection conn = new OleDbConnection(strConnection); // 建立DbCommand对象 OleDbCommand cmd = conn.CreateCommand(); cmd.CommandText = "SELECT * FROM Book"; // 打开数据库 conn.Open(); // 用DataReader读取数据 OleDbDataReader dr = cmd.ExecuteReader(); sbTable.Append(""); sbTable.Append("书名作者单价"); while (dr.Read()) { sbTable.Append(""); sbTable.Append(dr["BookTitle"].ToString()); sbTable.Append(""); sbTable.Append(dr["Author"].ToString()); sbTable.Append(""); sbTable.Append(dr["UnitPrice"].ToString()); sbTable.Append(""); } sbTable.Append(""); // 记住dr用毕必须关闭,否则会阻塞服务器 dr.Close(); // DbConnection是受托管的,可以不关闭 // 但为良好的编程习惯,应该关闭 conn.Close(); Response.Write(sbTable.ToString()); } 显示结果 图片如下: 第五天 学习目的: 掌握ADO.NET打开SQL SERVER数据库的方法。 今天做个非常普通的例子,做一个用户登录框。主要是通过这个练习认识一下SQL SERVER数据库的连接方法。和昨天的例子方法基本相同,很容易掌握的。 先建立SQL SERVER数据库,库名为AspNetABC,并建立一Member新表,建表SQL如下: CREATE TABLE [dbo].[Member] ( [MemberID] [int] IDENTITY (1, 1) NOT NULL , [MemberName] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL , [Password] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL , [Gender] [bit] NOT NULL , [Birthday] [datetime] NULL , [Email] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ) ON [PRIMARY] ALTER TABLE [dbo].[Member] WITH NOCHECK ADD CONSTRAINT [PK_Member] PRIMARY KEY CLUSTERED ( [MemberID] ) ON [PRIMARY] 与上一例子差不多,在web.config文件中再增加一行: