首页 > 资讯 > 网站设计
在ASP.NET中面向对象的编程思想
发布时间:2008-03-10   浏览次数:1153725
首先,我们还是来谈一下面向对象的编程思想吧。我想现在的主流编程思想无非两种:结构与面向对象。以前,在ASP中我们完全采用的是结构化思想。现在,asp.net可以完全支持面向对象的编程思想,这不得不说是一个质上的飞跃。   记得我在大约半年前给大家写过一篇,当时是由于看到一本小说的启发,发现任何东西都可以用面向对象的思想来看。我现在还是简单谈一下吧,面向对象无非是把世间万物当做一个类,要想使用类做事,必须创建类的实例。这很好理简,比方人是一个类,我们总不能说叫人去做事吧(这样没有针对性),我们往往说叫张三 or 李四去,这张三 or 李四是人这个类的一个实例。这是对象的概念。再讲一下是事件与动作,举个例子:起风了,下雨了,收衣服了。起风了,下雨了是事件,这个事件会激发收衣服这个动作,这个动作的执行者是对象。如果大家学过SQL Server的触发器,我想对这一点思想会更清楚。面向对象还比较重要的是继承(Inherits)与多态。这很好理解,比方,张三会收衣服,张三生的儿子继承了张三的特点,也会收衣服,这是继承,而且说不定张三的儿子还会开车,这是多态。   好了,对于面向对象理解我说这么一点,还是说一下在asp.net中如何用面向对象的观点来编程吧。我们在编web程序时,通常要要处理:UI(用户界面,也是数据的显示)与代码(如何处理数据的Code(代码)。为了达到UI与Code的完全分开,我们把UI当作一个对象,Code当作另我一个对象。当然我们要研究这两个对象的关系,还记得我们在编ASP程序时把同一段代码 Copy到很多页面,看来code是父类了,UI是子类了。不过他们都是从 System.Web.UI.Page继承过来。理清了类的关系,我们不难理解代码UI与Code分开的思想了。 关系图: 引入名称空间:using System.Web.UI 父类 page→ 很多子类Code(*.cs文件)→很多子子类 UI(*.aspx文件) 因为我主要是想大家了解这种编程思想,所以我只举一个简单的例子,我想大家有了思想,再是多找实例来看了。 文件两个: UI类: default.aspx 主要用来显示数据,用天DataGrid控件 Code类: default.aspx.cs 主要用来建立数据联接、查询、绑定数据于DataGrid控件的         里面我创建了自己的namespace名叫vagrant,以及类MyVagrant 数据库: data,里面有一个关系表student 为了说明default.aspx类是从default.aspx.cs 继承过来的,需要在default.aspx申明: Codebehind表明父类的源文件,Inherits="vagrant.MyVagrant" 表明该文件是从哪个类继承下来的。 现在给出源文件 default.aspx代码: default.aspx.cs 文件代码 注意:需要编译 /* 功能说明:default.aspx.cs用来将UI与源代码分开,此为代码部分,需要编译 Created By vagrant 01.10.17 个人主页:http://www.weavedream.net */ //引入必须的名称空间 using System; using System.Data; using System.Data.SqlClient; //引入使用SQL数据库所必须的名称空间 using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.HtmlControls; namespace vagrant //创建自己的名称空间 { public class MyVagrant :Page //我的类MyVagrant是从类System.Web.UI.Page类继承过来的 { protected DataGrid MyDataGrid; private void Page_Load(object sender, System.EventArgs e)//页面装载初始化,可检查页面是不是次被处理 { // 步:建立数据库联接,用面向对象的观点是创建一个SQL数据库联接对象的实例,并初始化 SqlConnection MyConnection=new SqlConnection("Server=(local);DataBase=data;UID=sa;PWD=;"); //第二步:读取数据库,来面向对象的观点是创建一个查询对象的实例,并初始化 SqlDataAdapter MyCommand=new SqlDataAdapter("select * from student",MyConnection); //:第三步:存储数据  DataSet ds=new DataSet(); MyCommand.Fill (ds,"vagrant"); // 第四步:绑定数据 MyDataGrid.DataSource =ds.Tables ["vagrant"].DefaultView MyDataGrid.DataBind (); } } }
业务咨询

Copyright 2003 - 2023 huinet.cn All Rights Reserved.
慧网公司 版权所有