叶子的家

~●    ~●  ~●          ~●   ~●~●                           ○
    离成功还很远,距离长着叻,Fighting!
posts - 40, comments - 654, trackbacks - 17, articles - 1
  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理
NoStore:可用在NET1.1和2.0。
Session和Cache:只能用在NET1.1,并且只能是InProc

NoStore:不会保存控件的服务器资源
Session和Cache:保存控件在服务器端,他们几乎是一样的只是存储的地方不同而已

NoStore:控件的Load, Unload 事件会被触发
Session和Cache:控件的Init, Load, PreRender, Unload事件不会被触发,但会触发AjaxCall, PreWriteScript和AjaxCallEnd,只要在类里面实现以下接口IAjaxCallEventHandler, IPreWriteScriptEventHandler即可

一下是一个例子:在AjaxPanel里面有一个Button,点击Button增加一个新的HyperLink放到panel里面。

private void Button1_Click(object sender, System.EventArgs e)
{
    HyperLink link 
= new HyperLink();
    link.Text 
= "HyperLink" + AjaxPanel1.Controls.Count;
    AjaxPanel1.Controls.Add (link);
}

NoStore:新增的HyperLink只会添加一次(不符要求)
Session和Cache:工作正常

出现这种情况的原因就是:NoStore不会保存控件的资源,新增的HyperLink不会被保存,无论多少次ajax请求,AjaxPanel都是第一次请求时的状态。

在NoStore模式下要解决这种情况,必须手工保存新创建的控件,然后页面请求时再次创建,代码如下:
protected ArrayList links;

private void Page_Load(object sender, System.EventArgs e)
{
    links 
= Session["links"as ArrayList;
    
if (links == null)
    {
        links 
= new ArrayList();
        Session[
"links"= links;
    }
    AddLink();
}

private void Button1_Click(object sender, System.EventArgs e)
{
    HyperLink link 
= new HyperLink();
    links.Add(link);
    link.Text 
= "HyperLink" + AjaxPanel1.Controls.Count;
    AjaxPanel1.Controls.Add (link);
}

private void AddLink()
{
    
foreach (HyperLink link in links)
    {
        AjaxPanel1.Controls.Add(link);
    }
}

Feedback

#1楼   回复  引用  查看    

2005-12-30 08:56 by 命运有自己的梦!      
我还一直为英文太差,看不这三种模式的区别发愁呢,想不到你先发贴了,支持!

#2楼   回复  引用  查看    

2005-12-30 14:32 by leves      
MagicAjax 怎么实现无刷新的页面跳转?有相关的示例吗?谢谢

#3楼   回复  引用  查看    

2006-01-18 15:24 by 听棠.NET      
文章 很好!!!支持!!

#4楼   回复  引用    

2007-03-05 18:27 by lodzio[未注册用户]
http://www.lolita-kir.in-cinta.info @X@

#5楼   回复  引用    

2009-04-06 22:06 by fengyantao[未注册用户]
梦想工作室 http://www.fytpjy.cn



发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 307704




相关文章:

相关链接: