一起谈.NET技术,asp.net控件开发基础(23)

  讨论了如何实现一个简单的数据源控件,但还没有完全的实现.这次我们具体的实现一些方法来加强数据源控件的功能.这里我们根据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("不支持删除操作");
      }

  (4)数据检索额外操作

  数据源控件还可以提供额外的数据操作,如排序,分页等

  DataSouceView的ExecuteSelect方法里的参数正是DataSourceSelectArguments类型,可以通过其AddSupportedCapabilities方法添加功能,然后调用RaiseUnsupportedCapabilitiesError方法检测操作要求与实现是否符合(即你指定了排序的功能,但数据源控件并未实现这个操作,防止弄虚做假的事情出现,核对一下功能:))。当然前提是数据源提供这样的功能实现,注意DataSourceSelectArguments类的属性与支持功能相对应,大家可以查看MSDN。

代码如下

     protected override IEnumerable ExecuteSelect(DataSourceSelectArguments arguments)
      {
          arguments.AddSupportedCapabilities(DataSourceCapabilities.Page);
          arguments.AddSupportedCapabilities(DataSourceCapabilities.Sort);
          arguments.RaiseUnsupportedCapabilitiesError(this);
      }

  接着还要重写DataSourceView的RaiseUnsupportedCapabilityError方法


protected override void RaiseUnsupportedCapabilityError(DataSourceCapabilities capability)
{
if ((((capability & DataSourceCapabilities.Page) != 0) && !CanPage) ||
(((capability & DataSourceCapabilities.RetrieveTotalRowCount) != 0) && !CanRetrieveTotalRowCount) ||
(((capability & DataSourceCapabilities.Sort) != 0) && !CanSort))
throw new NotSupportedException();

base.RaiseUnsupportedCapabilityError(capability);
}

  (5)执行数据操作(同步与异步)

  ExecuteInsert等方法为具体实现Insert方法则负责调用,其DataSourceView类支持数据的异步操作,如

public virtual void Insert (
    IDictionary values,
    DataSourceViewOperationCallback callback
)

  但默认情况下是同步的,所以还需要在子类实现一个同步的方法

      public int Insert(IDictionary values)
      {
          return ExecuteInsert(values);
      }

  以上是我认为值得注意的地方。DataSourceView类就是一个干活的类.反而DataSourceControl差不多什么也没做,只调用DataSourceView的相关方法.其只为DataSourceView类提供了ConnectionString属性(数据连接字符串).
DataSourceControl实现了IDataSource接口,当数据源发生变化时,则需要调用IDataSource接口的DataSourceChanged事件,DataSourceControl提供了RaiseDataSourceChangedEvent方法调用,如修改了ConnectionString属性就需要调用此方法,如

public virtual string ConnectionString
{
    get
    {
        if (this._connectionString != null)
        {
            return this._connectionString;
        }
        return string.Empty;
    }
    set
    {
        if (this.ConnectionString != value)
        {
            this._connectionString = value;
            this.RaiseDataSourceChangedEvent(EventArgs.Empty);
        }
    }
}

  以上为我学习方法的总结,都是比较重要的地方。如果列代码的话,不适合.因为大家数据库操作本来就会的。熟悉上面的操作过程然后再进行编写就好多了。还希望与大家多交流,错误的地方还请指出。

上一篇:asp.net控件开发基础(22)

时间: 2024-10-24 08:53:00

一起谈.NET技术,asp.net控件开发基础(23)的相关文章

asp.net控件开发基础(23)

上一篇讨论了如何实现一个简单的数据源控件,但还没有完全的实现.这次我们具体的实现一些方法来加强数据源控件的功能.这里我们根据SqlDataSource控件的一些功能来实现. 本篇示例源码来自Professional ASP.NET2.0 ServerControl and Component Development,即是模仿SqlDataSource而制作.我把控件功能减弱,代码整理了下,我们只关注重要的部分,一步一步上去. 一.概念 1.首先你必须熟悉ADO.NET的使用,然后抽象出一部分属性

一起谈.NET技术,asp.net控件开发基础(22)

上两篇讨论了如何定义结合数据源控件的数据绑定控件.这次我们一起来看下数据源控件是如何实现的.asp.net2.0已经为我们提供了很多数据源控件,相信大家都用过了,也希望大家对其有所熟悉.关于它能做什么就不说了.下面我们也一起来看看,如何简单的实现. 一.你必须了解的 1.关于数据源控件(DataSourceControl) 虽然表面看来,给数据绑定控件指定DataSourceID属性,数据源控件帮你做了一切工作,其实不然,数据源控件只负责收集与数据交互的相关信息,如:SqlDataSource的

一起谈.NET技术,asp.net控件开发基础(15)

继续我们的话题吧.自定义控件.如果你还不熟悉自定义控件开发的话,还请看看我以前写了几篇,希望对你有帮助 1.1何处继承 自定义控件一般从以下几个基类(此处不包含数据控件) 一.Control类(所有服务器控件的基类,算是比较底层的类,如果控件功能比较简单,要求不多,可直接继承此类.) 二.WebControl类(标准控件的基类,继承此类,你可以继承其丰富的公共属性,若标准控件中的控件没有你需要的控件,你可以继承此类) 三.CompositeControl 类(2.0新增的类,此类继承自WebCo

一起谈.NET技术,asp.net控件开发基础(13)

1.减轻服务器压力,增加用户体验 服务器功能是强大的,客户端脚本一点也不弱,现在的ajax技术和Atlas技术就是最好的证明,我们总是期待UI有一个好的效果,flash动画给我们带来了很酷的效果,我们至少也可以为我们的服务器控件添加客户端脚本,一方面减少了服务器端的回传,一方面又能为控件提供非常酷的效果.我想我们都很喜欢ATLAS里面很多很酷的控件吧,而且无刷新,服务器控件与客户端脚本交互使用,那会服务器控件变的更加完美. 经过上面的废话,下面我们进入正题 2.简单为服务器控件添加客户端脚本 我

一起谈.NET技术,asp.net控件开发基础(8)

有一些复合控件直接把按钮触发事件所需的事情封装好,另外一种则是自定义事件,更具灵活性,当然这是根据需要设计的.以下会以例子来说明的.下面我们假设我们控件中有两个按钮.以下不列出所有代码,具体可在文章最后下载代码. (1) 直接实现按钮事件 在控件中(以下代码并非实现复合控件)直接实现事件则无需自定义事件,如下代码(如果对数据回传有些不熟悉的话,可先看第三篇,希望对你有帮助) 示例一(只列出局部代码,具体可在文章最后下载代码) void IPostBackEventHandler.RaisePos

一起谈.NET技术,asp.net控件开发基础(2)

或许大家还对为何要重写Render方法存有疑惑,希望大家看看我举的例子,能够明白Render方法和其他两个方法的作用,然后真正明白为何一般情况下只须重写Render方法.我们知道我们每次编写控件时,都需要重写Render方法,我们发现在Control类中很多方法可以重写,但我们没有去重写他们,我们需要遵循一个原则,在需要重载的时候再去重写他们 我们还是先来看看与Render方法相关的两个方法 //RenderControl方法的基本实现 public void RenderControl(Htm

一起谈.NET技术,asp.net控件开发基础(18)

本篇继续上篇的讨论,可能大家已经在使用asp.net2.0了,DataSource属性不再使用,而是跟数据源控件搭配使用.现在讨论的绑定技术都是基于1.1版本,先熟悉一下,本质上是一样的,这样一步步的学习.对以后绝对有帮助.因为当你使用数据源控件,只需要设置一个DataSourceID,方便的同时你是否知道数据源控件帮你做了什么事情,如果你想觉的够用了,可以不用了解,但我相信你一定会有需求.上篇最后说过了,讨论还刚刚开始,我们大致把核心的方法都写出来了.下面我们继续. 一.控件对比 我们可以使用

一起谈.NET技术,asp.net控件开发基础(17)

本篇将开始介绍如自定义数据绑定控件,这里感谢很多人的支持,有你们的支持很高兴.这里首先需要大家熟悉asp.net模板控件的使用,还有自定义模板控件.因为数据绑定控件多是基于模板控件的. 一.回顾 如果你使用过asp.net内置的数据控件(如DataList,Repeater),你一定会这么做 1.设置数据源 DataSource属性 2.调用数据绑定  DataBind方法 3.在控件的不同模板内使用绑定语法显示数据 这三步应该是必须要做的 其他更多的 你可能需要对绑定的数据进行统一的一些操作(

一起谈.NET技术,asp.net控件开发基础(10)

集合属性相信大家都很熟悉也很常用,如DropDownList,ListBox等控件 <asp:DropDownList ID="DropDownList1" runat="server">            <asp:ListItem>测试1</asp:ListItem>            <asp:ListItem>测试2</asp:ListItem>            <asp:Lis