当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > asp.net 文件上传与刷新与asp.net页面与iframe之间的数据传输

ASP.NET
用 Asp.Net 建立一个在线 RSS 新闻聚合器的方法
关于前台调用后台事件__doPostBack函数
Bin 和 App_Code 文件夹介绍
.NET 2.0 的压缩功能代码
解决Visual Studio 2005 无法显示设计视图的方法
asp.net(c#)两种随机数的算法,可用抽考题
asp.net下url传递中文的解决方案
XmlReader 读取器读取内存流 MemoryStream 的注意事项
asp.net下创建、查询、修改带名称空间的 XML 文件的例子
使用.NET存储XML数据的方法
XslTransform.Transform将结果输出到字符串里的方法
安装 VS2005 SP1 有关问题的解决办法
asp.net下中文验证码,免费开源代码
自定义应用程序配置文件(app.config)
asp.net下使用DIME协议上传文件
动态改变ASP.net页面标题和动态指定页面样式表的方法
WEB上调用HttpWebRequest奇怪问题的解决方法
HTTP协议下用Web Service上传大文件的解决方案
asp.net下Response.ContentType类型汇总
ASP.NET User Control使用技巧一则

ASP.NET 中的 asp.net 文件上传与刷新与asp.net页面与iframe之间的数据传输


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 194 ::
收藏到网摘: n/a

众所周知微软所提供的updatepanel不能支持文件上传的异步刷新,但是往往当你在项目中的其他页面实现了异步刷新之后,客户就会问你为什么有文件上传的页面就不能实现异步刷新呢?这时我们可能说一堆理由,但是最后大部分还是会妥协于客户。 具体我们如何实现文件的异步刷新,目前网上已经有了很多文章来解决这个问题,但是会用到大量的javascript,由于本人编码功力尚浅,所以之今没有高清其中的所以然,但是在解决的方案中他们貌似都用到了iframe,这让我茅塞顿开,所以我就说说用这个处理刷新的思路。
首先一个实际的页面中往往是会有较多的内容,我们暂时把它分为A,B两个区域,A区域是内容区域,我们可以用updatepanel来实现异步刷新,B区域是上传区域,我们用div已经ifame占位,其中上传的具体功能实现我们可以放到C页面中,这样当点击按钮刷新B区域的时候,我们可以向C页面传值来更新里面的内容,同样当我们点击按钮删除或者保存内容时,也可以获取C页面中的内容,这样就基本上满足了无刷新的感觉。

其实这种方式并不能称之为异步刷新,因为我们只是用iframe来实现页面的局部刷新从而满足一种无刷新的感觉而已。

如果这样处理的话,asp.net页面与iframe之间的传值就会成为另一个问题,其实这个问题如果你知道,就会比较简单,但是不知道的话,就有点无从下手。
网上可能也提供了很多方案处理传值,我使用的是使用javascript来获取控件从而取到他里面所包含的值。

这个是获取iframe f1,以及页面C中的 img控件
var objFrame = document.getElementById("f1");
var objPicture = objFrame.contentWindow.document.getElementById("imgPicture");
当然你也可以在页面C中去获取父页面的控件,从而获取值
var objHid = this.parent.document.getElementById("")

这个是包含ifrmae的div
<div id="iconpicture">
<iframe id="f1" style="width: 300px; height: 300px" src="UploadImage.aspx" scrolling="no"
frameborder="0" border="0" frameborder="no"></iframe>
</div>

这个实现方式我已经在项目中成功的使用了,其实如果这样处理主要的难点已经不再于具体功能的实现,而在于页面的布局在多浏览器下的适应了。当然我提供的这些javascript 是满足多浏览器的。