版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、从零开始学ASP.NET(基础篇)第一天学习目的: 掌握最基本的Label、TextBox、Button控件用法 掌握用StringBuider类连接字符串 理解服务器的环境变量StringBuilder类:命名空间是:System.Text。StringBuilder类是个高效的类,StringBuilder.Append连接字符串的方法是非常快的。用于连接大量的字符串,其速度的优越性就会体现出来。先举几个例子:在cs或vb文件的头部加上C#using System.Text;VBImports System.TextC#StringBuilder sbFirst = new StringB
2、uilder();sbFirst.Append(“这是第一个学ASPNET的例子”);sbFirst.Append( “这个例子太简单”);sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”);Response.Write(sbFirst.ToString();VBDim sbFirst As StringBuilder = New StringBuilder()sbFirst.Append(“这是第一个学ASPNET的例子”)sbFirst.Append( “这个例子太简单”)sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”)Response.W
3、rite(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 i
4、n Request.ServerVariables)info.Append();info.Append(objVar.ToString();info.Append( = );info.Append(Request.ServerVariablesobjVar.ToString();info.Append();labServerVariables.Text = info.ToString();结果显示:图片如下:这样我们就可以这样用Response.Write(Request.ServerVariablesREMOTE_ADDR);/ IP地址Response.Write();Response.W
5、rite(Request.ServerVariablesURL);/ 网页的URL第二天学习目的: 掌握文本框的用法 初次接触trycatch语法今天内容很轻松,用一个例子,输入年月日,判断输入是否正确图片如下:用个文本框,ID分别为txtYear,txtMonth,txtDate;检验按钮的代码为:private void btnCheck_Click(object sender, System.EventArgs e)int year, month, date;/ 先把输入的字符转成int类型,如果非数字型,/ 会触发错误tryyear = Convert.ToInt32(txtYear.
6、Text);month = Convert.ToInt32(txtMonth.Text);date = Convert.ToInt32(txtDate.Text);catchlabCheckInfo.Text = 输入的是非数字字符。;return;/ 如果第一步检验合格,就把输入的数字转化为日期格式/ 如果不符合日期格式即引发错误tryDateTime dt = new DateTime(year, month, date);catchlabCheckInfo.Text = 输入的数字不符合日期格式;return;labCheckInfo.Text = 输入正确; 嗯,补充一下,关于Stri
7、ngBuider在处理字符串的时候很多人喜欢+=,其实对于string来说,一旦定义了就无法更改了所谓的+只是新建的一个新的string变量并赋值所以对于尽量使用StringBuider的Append的方法,这样将大量的节省服务器的资源第三天学习目的: 掌握下拉列表框的用法,并理解AutoPostBack属性; 理解IsPoskBack及用法; 初识DataTable的增加列、行,与下拉列表框绑定的方法。今天的内容稍多些,而且涉及一些比较常用的,如IsPostBack及DataTable的基本用法。知识点:IsPostBack:在页面onLoad之间是false值,而当从服务器回传后,该值变为
8、true。当页面中的Button或ImageButton等触发事件,都会把表单回传到服务器,而返回时又会引发onLoad事件。为了节省服务器资源,有些加载中需进行一次,而不需要在回传后多次发生,可以用!IsPoskBack来作为条件,那么页面第一次加载后,以后就不会发生。该属性可以帮助你提高程序的性能。DataTable:即数据表,.Net 程序中最常用的类,特别是数据库开发中,没有该类的程序是不可想象的。先做个小程序来练练手,很简单,就一个下拉菜单,取名dlstWeb。在属性的Itmes选项中打开以下对话框,添加各项:图片如下:ASPX中的代码为:新浪 搜狐网易在下拉框的SelectedIn
9、dexChanged事件中的加入代码:private void dlstWeb_SelectedIndexChanged(object sender, System.EventArgs e)Response.Write(window.open( +dlstWeb.Selectedvalue + ););按F5运行,可是我们发现这下拉框选择时什么事也没发生。原来原因是出在下拉框的AutoPostBack属性上,把它设为true后再试试,一切OK了。下面我们增加些难度,下拉框中的内容很多情况下不是事先固定的,而是要动态添加。这里设计是用一数据表DataTable与之联系起来。另建一文件,按上添加一
10、下拉框,取名dlstWeb,先设AutoPostPack为false,否则在刚启动而面就触发SelectedIndexChanged事件,弹出窗口就乱飞了。在onLoad事件中添加代码,注意DataTable用法及IsPoskBackDataTable属于System.Data命名空间,所以如果页面没预添加,可以自行增加这一行。private void Page_Load(object sender, System.EventArgs e)/ 用IsPostBack判断,只在没有回传时才初始化/ 这样可以防止每次刷新或回传时,都执行一次以下代码/ 可以节省服务器的资源了。if (!IsPost
11、Back)DataTable dt = new DataTable();DataRow dr;/ 在表中增加字段dt.Columns.Add(WebName, typeof(string);dt.Columns.Add(WebUrl, typeof(string);/ 表中增加行dr = dt.NewRow();drWebName = 新浪;drWebUrl = ;dt.Rows.Add(dr);dr = dt.NewRow();drWebName = 网易;drWebUrl = ;dt.Rows.Add(dr);dr = dt.NewRow();drWebName = 搜狐;drWebUrl
12、 = ;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
13、 e)Response.Write(window.open( +dlstWeb.Selectedvalue + ););小结:今天的一些知识非常重要,为了理解,程序的难度并不高。但这是以后程序设计的基础,所以这些你一定要掌握。 VB.NET增加字段代码稍有不同,如下:/ 在表中增加字段dt.Columns.Add(WebName, GetType(String)dt.Columns.Add(WebUrl, GetType(String)其它都差不多了。每四天学习目的: 学习ADO.NET用法,并如何用DataRearder读取数据今天练习数据库的最基本用法,如何打开数据库。首先在网站设置文件w
14、eb.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_L
15、oad(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对象
16、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(drBookTitle.ToString();sbTable.Append();sbTable.Append(drA
17、uthor.ToString();sbTable.Append();sbTable.Append(drUnitPrice.ToString();sbTable.Append();sbTable.Append();/ 记住dr用毕必须关闭,否则会阻塞服务器dr.Close();/ DbConnection是受托管的,可以不关闭/ 但为良好的编程习惯,应该关闭conn.Close();Response.Write(sbTable.ToString();显示结果图片如下:第五天学习目的: 掌握ADO.NET打开SQL SERVER数据库的方法。今天做个非常普通的例子,做一个用户登录框。主要是通过这个
18、练习认识一下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
19、,Birthday datetime NULL ,Email nvarchar (50) COLLATE Chinese_PRC_CI_AS NULL ) ON PRIMARYALTER TABLE dbo.Member WITH NOCHECK ADD CONSTRAINT PK_Member PRIMARY KEY CLUSTERED (MemberID) ON PRIMARY 与上一例子差不多,在web.config文件中再增加一行:在面中添加二个文本框,txtMemberName、txtPassword,并设置txtPassword的TextMode为Password。设置按钮btnL
20、ogin。btnLogin的事件代码如下:private void btnLogin_Click(object sender, System.EventArgs e)/ 先检验输入正确性if (txtMemberName.Text = String.Empty txtMemberName.Text.Trim() = )Response.Write(alert(帐号不能为空);return;if (txtPassword.Text = String.Empty txtPassword.Text.Trim() = )Response.Write(alert(没有输入密码);return;strin
21、g strConnection = ConfigurationSettings.AppSettingsSqlDatabase1;string sqlMember = SELECT MemberName ,Password FROM Member + WHERE MemberName = + txtMemberName.Text.Trim() + + AND Password = + txtPassword.Text.Trim() + ;/ 连接SqlServer数据库SqlConnection conn = new SqlConnection(strConnection);/ 建立SqlCom
22、mandSqlCommand cmd = conn.CreateCommand();cmd.CommandText = sqlMember;conn.Open();/ 建立DataReaderSqlDataReader dr = cmd.ExecuteReader();/ 判断DataReader是否为空记录if (dr.HasRows)Response.Write(alert( + txtMemberName.Text + 欢迎你!);elseResponse.Write(alert(找不到该会员,或密码错误。);/ 千万不要忘记关闭DataReaderdr.Close();conn.Clo
23、se();好了,一个非常简单的登录框做好了。当然在实际程序中还应加入跳转等,这个就留给你做了。第六天学习目的 掌握如何用ADO.NET插入新的记录我们学得好快,今天做一个简易的新闻发布网页,可以说是个演示型的,只是让大家能理插入数据的最主要步骤。掌握今天的内容,我们就有基础可以做一个稍有实用的新闻程序了。为了不使注意力分散,程序没有加入输入的验证,很快我会接下去写一个验证输入的方法。图片如下:仍用昨天的方法新建一数据表,SQL语句如下:CREATE TABLE dbo.NewsArticle (NewsArticleID int IDENTITY (1, 1) NOT NULL ,Title
24、nvarchar (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,SubTitle nvarchar (50) COLLATE Chinese_PRC_CI_AS NULL ,Content ntext COLLATE Chinese_PRC_CI_AS NOT NULL ,Writer nvarchar (10) COLLATE Chinese_PRC_CI_AS NULL ,PubTime datetime NOT NULL ) ON PRIMARY TEXTIMAGE_ON PRIMARYALTER TABLE dbo.NewsArticle WITH
25、NOCHECK ADD CONSTRAINT DF_NewsArticle_PubTime DEFAULT (getdate() FOR PubTime,CONSTRAINT PK_NewsArticle PRIMARY KEY CLUSTERED (NewsArticleID) ON PRIMARY GO按昨天的方法加入头部的语句,在提交按钮中建立以下事件:private void btnPublish_ServerClick(object sender, System.EventArgs e)string strConnection = ConfigurationSettings.AppS
26、ettingsSqlDatabase1;/ 连接SqlServer数据库SqlConnection conn = new SqlConnection(strConnection);/ 建立SqlCommandSqlCommand cmd = conn.CreateCommand();cmd.CommandText = INSERT INTO NewsArticle (Title, SubTitle, Writer, Content) valueS (+ + txtTitle.Text + ,+ + txtSubTitle.Text + ,+ + txtWriter.Text + ,+ + tx
27、tContent.Text + );conn.Open();/Response.Write (cmd.CommandText);/ 插入记录trycmd.ExecuteNonQuery();catch (Exception ex)Response.Write(alert(输入错误,数据库不能更新。);finallyconn.Close();注意Command对象的ExecuteNonQuery()方法使用,该方法可以用于插入、更新、删除等操作,是Command对象的重要方法。今天介绍了Command语句的最基本用法,下次还将介绍占位符的用法。好了,各位先消化一下,明后天将做实用的东东了。 第七
28、天学习目的 接触验证控件昨天介绍了SQL SERVER插入数据,但是我们省略了验证输入这一步。以前的做法是用语句逐个判断输入的正确性,如是否为空,长度是否超过等。现在.NET中有了验证控件,可以使我们在编程的语句中大在简化了。今天介绍验证控件中最基本的一个,RequeiredFieldValidator控件,是用来判别否输入控件是否为空值,如为空则引发错误。RequeiredFieldValidator可以用来验证TextBox、ListBox、DropDownList、RadioButtonList及Html控件中的InputText、TextArea、Select、InputFile等。属
29、性介绍:ControlToValidate:指点验证某一控件的控件名,如为空,将引发异常;ErrorMessage:错误提示信息;IsValid:用于判断是否通过验证;Display:有三个值,None表示错误时不显示信息,但在ValidationSunmmary控件中显示;Static表示不论错误提示是否出现,都占页面空间;Dymatic:只有错误提示才占用空间。Text:文本内容。和ErrorMessage一起使用时,将显示Text错误信息。该种情况可以通过ValidationSummay控件显示ErrorMessage属性的提示。使用方法:设置:txtTitle:MaxLength(50
30、);txtSubTitle: MaxLength(50);txtWriter: MaxLength(10);这样可以防止输入过长字符串rfvTitle:ControlToValidate(txtTitle)、ErrorMessage(“标题必须输入。”)rfvContent:ControlToValidate(txtTitle)、ErrorMessage(“内容必须输入。”)这样在没有验证通过时,会出现下图信息提示,并不执行插入语句。直到验证正确后,才执行数据更新。图片如下:第八天学习目的 学会SQL中的占位符用法在鲸鱼这几天忙死了,好几天没写了,真对不起各位。这几天让XHTML闹得不开心,虽
31、然以前也知道这个,但没太在意。可现在我是如梦初醒,我发觉XHTML是个信号,所以这几天不得不仔细研究一下这个。很笨,我还没发觉XHTML的奥妙。确实如此,没上过台面,真不知这桌菜怎样好吃。少说了,回到正题。先把以前的Command的CommandText重新写过:cmd.CommandText = INSERT INTO NewsArticle (Title, SubTitle, Writer, Content)+ valueS ( Title, SubTitle, Writer, Content );这样代码是否很清晰了,我们可以避免一大串的难以看懂的的语句了。接下来,我们就给这些定位符赋予
32、属性和值了:cmd.Parameters.Add(Title, SqlDbType.NVarChar, 50);cmd.Parameters.Add(SubTitle, SqlDbType.NVarChar, 50);cmd.Parameters.Add(Writer, SqlDbType.NVarChar, 10);cmd.Parameters.Add(Content, SqlDbType.NText);以上我们给每个占位符定义一个值类型,相信不难看懂吧。接者再给于值:cmd.ParametersTitle.value = txtTitle.Text.Trim();if (txtSubTit
33、le.Text = string.Empty txtSubTitle.Text.Trim() = )cmd.ParametersSubTitle.value = DBNull.value;elsecmd.ParametersSubTitle.value = txtSubTitle.Text.Trim();if (txtWriter.Text = string.Empty txtWriter.Text.Trim() = )cmd.ParametersWriter.value = DBNull.value;elsecmd.ParametersWriter.value = txtWriter.Text;cmd.ParametersContent.value = txtContent.Text;其实,也可以这样写:cmd.Parameters.Add(Title, SqlDbType.NVarChar, 50) .value = txtTitle.Text.Trim();这要看你喜欢了。不错吧,程序是否很有条理
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025购房借款合同书范文
- 跨学科知识联合的未来发展趋势
- 包鱼塘合同范例
- 汕头大学《运作管理》2023-2024学年第一学期期末试卷
- 山东电力安装合同范例
- 2024至2030年电动铅笔刨电机项目投资价值分析报告
- 售后网合作合同范例格式
- 场地承包合同范例
- 归侨侨眷食品救助合同范例
- 煤炭装袋销售合同范例
- 企业发展未来5年规划
- 2024-2025学年四年级科学上册第一单元《声音》测试卷(教科版)
- 四川省成都市2023-2024学年七年级上学期期末数学试题(含答案)
- 2024年交管12123学法减分考试题库附完整答案(网校专用)
- L04小尺寸MOSFET的特性
- 《昆虫记》阅读题及答案
- 气体灭火系统验收表1
- 千分尺校验记录表(参照模板)
- (完整版)第二章-铸铁的结晶及组织形成课件
- SparkCCD6000操作规程操作版分解
- EN779-2012一般通风过滤器——过滤性能测定(中文版)
评论
0/150
提交评论