日期:2010-08-24  浏览次数:20370 次

在atlas里面有UpdatePanel控件,支持局部更新,只要指名Mode="Conditional",当然,ScriptManager也要设置EnablePartialRendering="true"。

局部更新,使用的是xmlHttp。过程如下:
1:postback的时候,页面的js把页面上数据postback(是整个页面都要postback的)
2:后台接收到请求,开始处理(页面的pageLoad什么的都可以触发了)
3:处理完毕之后,只把要更新的数据发回到页面(根据你要更新的UpdatePanel的名称来确定回发那一部分数据。就是this.updatePanelXX.Update()那一句代码了)
4:页面(客户端)只对这一部分回发数据进行更新(这就是所谓的局部更新,方法就是找到updatePanle,然后UpdatePanel.InnerHtml=PostBackData。就是一个直接替换。)

由此看来,所谓局部跟新就是只把指定的updatePanel的部分重新绘制(回发服务器的时候是整个页面都要回发的;后台代码也是和以前一样每一个都会处理;但是处理的结果只有部分被返回到客户端)。

这样一来,如果你想在UpdatePanle处理的时候顺便引发一个页面的js处理就很困难了。因为你回发的数据全部被更新到了一个小角落,以前的Response.Write(js)根本不起作用。

解决的方法是这样的:
 this.Page.ClientScript.RegisterStartupScript(this.GetType(), "OpenOverViewPart", openScript);使用RegisterStartupScript方法来注册js函数,然后就可以顺利执行。

其实执行也不是那么顺利,因为atlas在执行局部跟新之后,会把页面上所有的js都放到一起---多管闲事---所以会造成一些小影响:很多js都有诸如<!-之类的注释符号,一不小心,你自己的js也会被注释起来。这个的确比较麻烦。
解决的办法比较下X,需要自己控制一下js输出的风格,多加几个回车换行,以示不属于注释
    string openScript = "\n\t";
         openScript = "<script" + " type='text/javascript'>\r\n"
            + "\r\n"
            + "var a=0;\r\n"
            + "opener.top.__doPostBack('" + Request.Params["refresh"] + "','refresh');\r\n"
            + "window.opener.focus();"
            + "window.close();"
            + "<" + "/script" + ">";