上一篇讨论了如何实现一个简单的数据源控件,但还没有完全的实现.这次我们具体的实现一些方法来加强数据源控件的功能.这里我们根据SqlDataSource控件的一些功能来实现.
本篇示例源码来自Professional ASP.NET2.0 ServerControl and Component Development,即是模仿SqlDataSource而制作.我把控件功能减弱,代码整理了下,我们只关注重要的部分,一步一步上去.
一.概念
1.首先你必须熟悉ADO.NET的使用,然后抽象出一部分属性和方法,如执行sql语句命令类型,这个属性你便可以抽象出来,当是控件功能的一部分.所以这部分代码不再列出,大家仔细看就会明白了.
2.数据操作注意事项
(1)数据前后操作事件,我们见过SqlDataSource的数据前后操作事件,如读取数据,前后事件则是Selecting和Selected
假设getData方法是读取数据库,那么写成代码就是这样
protected override IEnumerable ExecuteSelect(DataSourceSelectArguments arguments)
{
SqlDataSourceSelectingEventArgs e = new SqlDataSourceSelectingEventArgs(com, arguments);
//尝试数据检索操作前引发 Selecting 事件
OnSelecting(e);
return getData();
SqlDataSourceStatusEventArgs ee = new SqlDataSourceStatusEventArgs(com, -1, null);
//尝试数据检索操作后引发 Selecting 事件
OnSelected(ee);
}
其他数据操作也一样
(2)自动重新绑定
读取数据是基本的,不存在对数据库的更改,当对数据进行增,删,改时.数据发生了变化,以前我们则是手动进行重新绑定,现在也是,只不过方式变了而已.DataSourceView中存在OnDataSourceViewChanged 方法,我们只需要调用这个方法引发DataSourceViewChanged事件通知数据发生了变化,就会帮你自动重新绑定了,即除了读取数据以外的其他数据操作都需要调用这个方法.假设是删除操作,则代码如下
protected override int ExecuteDelete(IDictionary keys, IDictionary oldValues)
{
SqlDataSourceCommandEventArgs e = new SqlDataSourceCommandEventArgs(com);
OnDeleting(e);
affectedRows = com.ExecuteNonQuery();
OnDataSourceViewChanged(EventArgs.Empty);
SqlDataSourceStatusEventArgs ee = new SqlDataSourceStatusEventArgs(com, affectedRows, exception);
OnDeleted(ee);
return affectedRows;
}
(3)Can属性
指定能否进行数据操作,读取数据默认可以,其他的操作可以在方法开始部分加上如下代码,假设是不支持删除操作
protected override int ExecuteDelete(IDictionary keys, IDictionary oldValues)
{
if (!CanDelete)
throw new NotSupportedException("不支持删除操作");
}