论坛交流
首页办公自动化| 网页制作| 平面设计| 动画制作| 数据库开发| 程序设计| 全部视频教程
应用视频: Windows | Word2007 | Excel2007 | PowerPoint2007 | Dreamweaver 8 | Fireworks 8 | Flash 8 | Photoshop cs | CorelDraw 12
编程视频: C语言视频教程 | HTML | Div+Css布局 | Javascript | Access数据库 | Asp | Sql Server数据库Asp.net  | Flash AS
当前位置 > 文字教程 > Asp.net教程
Tag:静态页面,treeview,gridview,repeater,dataset,sqldatareader,ado.net,上传,三层,ajax,xml,留言本,新闻发布,商城,注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,触发器,socket,form认证,登录,视频教程

在atlas里面的UpdatePanel控件中调用javascript,以及updatePanel的一些原理

文章类别:Asp.net | 发表日期:2008-10-5 22:11:10

在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" + ">";

视频教程列表
文章教程搜索
 
Asp.net推荐教程
Asp.net热门教程
看全部视频教程
购买方式/价格
购买视频教程: 咨询客服
tel:15972130058