科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件ASP.NET中基类页的设计和使用(2)

ASP.NET中基类页的设计和使用(2)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文给出了定义多个基类页的方法和基类页的设计技巧,供大家参考!

作者:jiyang 来源:天极网  2007年8月31日

关键字:

  • 评论
  • 分享微博
  • 分享邮件

到这一步,我们的基类页已经很好用了,但还有一个小问题,也就是前面说的,在WebForm中无法实现界面级的继承,那么基类页的QueryAndBind方法,将无法知道查询结果要绑定到哪一个表格,这时我们的做法是在基类页中声明DefaultGrid属性,让继承页来告知当前的表格控件。

修改后的代码:

QueryPeopleForm : QueryFormBase

OnQueryButtonClick()

{

 InitControls(gridMain);

 Query query = new Query();

 query.Add(“Name”, txtPeopleName.Text, QueryOperator.Like);

 query.Add(“Age”, txtPeopleAge.Text, QueryOperator.Equal);

 QueryAndBind(new PeopleManager(), query.GetSql());

}

至此,基类页的功能已经完整了,但仍然不够,如果我们以后想改变查询按钮点击的行为,比如查询结果为空时,要弹出对话框提示,这时仍然要到处修改页面代码,这不是我们所希望的,于是我们将QueryButton的OnClick操作也放在基类页了中执行,继承页只要初始化数据访问组件和设置查询条件即可。

QueryPeopleForm : QueryFormBase

void Initialize()

{

 // 指定页面对应的Manager

 Manager = new PeopleManager();

 // 绑定控件

 InitControls(gridMain, btnQuery);

}

void GetQueryInfo(Query query)

{

 //获得查询条件

 query.Add(“Name”, txtPeopleName.Text, QueryOperator.Like);

 query.Add(“Age”, txtPeopleAge.Text, QueryOperator.Equal);

}

QueryFormBase:

private IManager manager = null;

public IManager Manager

{

 get { return manager; }

 set { manager = value; }

}

void InitControls(GridView grid, Button queryButton)

{

 this.defaultGrid = grid;

 this.queryButton = queryButton;

 queryButton.Click += new EventHandler(QueryButton_Click);

}

void QueryButton_Click(object sender, EventArgs e)

{

 Query query = new Query();

 GetQueryInfo(Query);

 QueryAndBind(manager, query.GetSql());

}

总的代码可以从附件中下载,大家可以加入断点,看看基类,继承类页的代码执行顺序。

应该说基类的设计相对复杂,但好处是继承页的代码变得清楚了,没有多余重复的代码。

而基类页的设计其实是有技巧的,总结起来有以下几条:

1、首先以最直接的方式写出页面代码

2、提取公用方法和添加辅助类

3、提取事件处理流程到基类页中

4、在基类页中设计需要继承页重载的方法与事件

从设计上来讲,用基类页的方式来统一操作、简化页面代码是一种非常直观的方式,缺点是随着项目的演化,基类页会变得大而全,不容易被新的项目重用,这时我们就可以考虑把其中的一部分功能放到用户控件和自定义组件中来实现,以减少耦合性和提高重用性。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章