欢迎来到天天文库
浏览记录
ID:20357971
大小:101.61 KB
页数:21页
时间:2018-10-09
《asp.net中程序构架与程序代码的分离》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、ASP.Net中程序构架与程序代码的分离一年前,当本人拿到一个名叫TWIG的PHP程序时,立即被作者OOP编程思想所折服,很难想像TWIG中所有的功能(行事历、邮件、个性化)均在一个PHP文件0中执行完成,这就得益于作者采用了程序代码与页面构架分离的思想,但是我也看到尽管作者做了很大的努力,但由于PHP的局限性,程序并没有真正做到代码与构架的分离,这个主文件由于要执行的功能太多,所以其require的模块文件相当之多,至使整个文件依然显得十分零乱,本人愚昧,当时花了半个月的时间,才真正明白程序的构架,分析代码之苦
2、,无人能知啊(黯然泪下)。TWIG程序对我此后的编程有着很大的影响,但是即使这样的作品,依然没有摆脱程序代码与HTML代码混杂的局面。程序代码与页面构架的分离是WEB程序员多年的梦想。在出现之前,无论是ASP、PHP还是JSP,程序代码与HTML代码都是混杂在一起的,这种做法,虽然在WEB技术初期受到赞扬,但是随着时间的的推移,它的弊端是越来越明显,当程序代码很长时,HTML代码与其混杂,程序的可读性变得很差,让人无法分清程序真正要表示的页面构架。而新技术则通过Codebehind、用户控件(UserContro
3、l)以及自定义控件(CustomContro1)等方法真正做到了代码的分离。这是一个了不起的进步,大家可以在本文中看到分离代码后的程序的结构是多么的清晰。为了便于理解,这里设计的页面比较简单,页面分为三个主要的部分,头部包含一个AdRotator控件(用于显示广告)与一个Labe1控件(用于显示当前广告链接地址);中部是一个登陆页面,包括两个TextBox控件(分别用于输入用户名与密码)、一个Label控件(显示登陆是否成功)与一个Button控件(作为提交按钮);底部包含两个Label控件(分别显示当前用户名与
4、用户权限)。熟悉的朋友,马上就会意识到头部由于使用了AdRotator控件,所以必定存在OnAdCreated事件以便在Label控件显示相应链接;而中部由于使用Button控件做为提交按钮,所以必定有一个OnClick事件处理。ICodeBehind首先我们就看看如何使用CodeBehind方法来实现代码与页面构架的分离,下面给出的源程序是主程序一:例程中,大家可以清楚地看到程序中不包含任何c、VB、JavaScript来处理OnAdCreated与OnClick事件,但是执行本程序,程序能够正常使用(如图2-
5、1与图2-2)。这便是使用CodeBehinde的结果,事件处理已经被转移到其它程序中定义执行。请大家注意本例中第一行的信息:一般在程序中,Page指令都在设定本程序应当使用什么语言(使用Language属性),而本例中没有出现Language属性,而是出现了两个新的Page属性:Src与Inherits。Src属性设定事件处理真正的代码位置,Inherits属性则设定需要引入的类名。可以看到本例中定义事件处理的文件是,我们来看看它的具体内容:usingSystem;using;using;using;using
6、;using;using;publicclassAspcn:Page{//声明WebForm中出现的控件publicLabellblAdText,lblUserName,lblPurview,lblMsgShow;publicTextBoxtbUserName,tbPasswd;publicButtonbtnSubmit;publicAdRotatorad;privatestringstrConnString=〃server=(local)//Feidao;database=aspcn:Trusted_Conne
7、ction=yes〃://处理Adrotator控件建立事件publicvoidAdCreated(Objectsrc,AdCreatedEventArgse)publicvoidSubmit_Click(Objectsender,EventArgse)SqlConnectionMyConn=newSqlConnection(strConnString);0;stringstrUserName,strPassword,strSelect:strUserName=;strPassword=;strSelect="s
8、elect^frombbs_userwhereid=’"+strUserName+〃’andpassword=’〃+strPassword+〃’〃;SqlCommandMyComm=newSqlCommand(strSelect,MyConn):SqlDataReaderdr=();if(0)//登陆成功=dr[〃id〃].ToStringO:=dr[〃purview〃]
此文档下载收益归作者所有