2004-7-8+ 用户控件(使用缓存)

-----示例下载----------

ASP.NET 缓存功能是一项很重要的功能,而这其中使用最多的就是利用用户控件实现的片段缓存。
有时候,缓存整个页是不实际的;可能需要为每个请求动态创建页的某些部分。在这些情况下,您可能值得花时间来标识与需要大量的服务器资源来构造的页请求相关联的对象或数据。一旦标识了这些项,您就可以通过在 Web 窗体用户控件中创建这些项将它们从页的其他部分分离出来,然后在一段指定的时间中对这些项进行缓存,以节省服务器资源。这就是通常所说的片段缓存。这项技术允许您将需要花宝贵的处理器时间来创建的页的某些部分(例如数据库查询)与页的其他部分分离开。您可以选择允许为每个请求动态生成需要较少服务器资源的页的部分。
要使用户控件具有缓存功能,只要在.ascx文件的顶部添加 @OutoutCache 指令即可,关于这个指令的详细内容可以参看sdk文档的这一部分:ms-help://MS.NETFrameworkSDKv1.1.CHS/cpgenref/html/cpconoutputcache.htm
下面我们来看常用的方式:
<%@ OutputCache Duration="30" VaryByParam="None"%>
上面是说缓存这个控件30秒,并且缓存内容不随任何指定参数发生变化。

下面我们可以用这个控件了,像通常的做法,就是在.aspx页面用 @Register 指令声明,并在页面中添加。如果只是想在.aspx页面就完成整个工作,那到这里一切就算完了。
<user:timex id="uctime" runat="server"></user:timex>
但是如果想在codebehind中使用控件的属性,我的意思是说在.cs文件中指定属性,或是动态加载一个用户控件,那就得多花一些心思。
先来在codebehind中使用一下这个带缓存的控件。
uctime.times=System.DateTime.Now.ToString();
times是这个控件的一个属性,作用是指定控件中label的text值。这个页面在初次运行时没有任何问题,但是当你刷新页面后,就会发生错误,提示说这个控件根本就不存在!你还可以用动态加载的方式运行一下这个例子,也会发生同样的错误。
如果在页中声明并使用了为输出缓存指定的用户控件,则 ASP.NET 页分析器将根据用户控件的创建方式,对两个对象类型中的一个类型进行实例化。如果以声明方式创建用户控件,会添加 StaticPartialCachingControl 对象;如果使用 LoadControl 方法以编程方式创建用户控件,会添加 PartialCachingControl 对象
上面的意思是:一旦你使用了一个具有OutoutCache内容的用户控件,系统会根据控件的创建形式相应的建立新的缓存对象,然后在整个缓存周期内一直使用这个新的缓存对象,而不是使用用户控件本身。也就是说页面初此加载时是使用的用户控件本身,接下来在缓存周期内就是使用的缓存对象。这就是为什么上面会出现错误的原因。
找到了原因,解决问题就简单多了。我们可以在.cs中加一个判断,然后为用户控件本身和缓存对象分别添加属性的赋值。(在这里说说办法简单,偶为了找这个答案可费了大力气了,不过最后还是csdn的高人帮偶解决了,嘿嘿)
这个还是得分页面声明和动态加载两类来说。
先看页面声明时的做法:
protected prac2.uc_cache uctime;
private void Page_Load(object sender, System.EventArgs e)
{
   set();
}

private void set()
{
   if(uctime!=null)
   {
      uctime.times=System.DateTime.Now.ToString();
   }

}
先在codebehind中声明控件,然后在使用属性的时候判断,如果控件不为空,就表示是初次加载。这个时候给属性赋值。这样当页面再次加载时,因为使用了缓存,该流程就不进了。但是属性值依然存在。
再看动态加载时的做法:
protected System.Web.UI.WebControls.PlaceHolder placetime;
private void Page_Load(object sender, System.EventArgs e)
{
   loaduc();
}
private void loaduc()
{
//先是动态加载该控件,在初次加载时,其类型显然是uc_cache
   Control ucc=LoadControl("uc_cache.ascx");
   placetime.Controls.Add(ucc);
   prac2.uc_cache uctime=null;

//第一次执行的流程
   if(ucc is prac2.uc_cache)
   {
      uctime=(prac2.uc_cache)ucc;
   }

//第二次及其以后整个缓存周期执行的流程
   else if(ucc is PartialCachingControl&&((PartialCachingControl )ucc).CachedControl!=null)
   {
      uctime=(prac2.uc_cache)((PartialCachingControl)ucc).CachedControl;
   }

//最后,给属性赋值
if(uctime!=null)
{
   uctime.times=System.DateTime.Now.ToString();
}

}
这个就更加清楚的说明了缓存控件的工作原理,先是加载一个控件,然后根据是用户控件本身还是缓存控件来分别进行操作,最后给控件的属性赋值。这段程序通过使用一个中间量来完成对控件属性的操作,ucc是其中动态加载的控件,第一次的时候为用户控件,而到了第二次,就变成了一个缓存控件,程序分别对这两次改变进行不同的操作,最后的结果都是把ucc正确的赋给了uctime,最后uctime得以操作属性。
在转载精华部分的第13篇文章也是就该内容展开的讨论,实际上我就是看这篇文章才弄明白了PartialCachingControl的用法。
我在csdn的发帖的位置,感兴趣的可以去看看:
http://community.csdn.net/Expert/TopicView.asp?id=3138685
到这里,用户控件的基本内容应该就结束了。在以后的实践中,应该努力的学习怎么更好的使用这一强大的技术-用户控件。

 

posted on 2006-06-29 09:29  Notus|南色的风  阅读(262)  评论(0编辑  收藏  举报