用iframe实现不刷新整个页面上传图片的实例


Posted in Javascript onNovember 18, 2016

经常用到上传图片即时预览的功能,实现方式很多,用flash+js实现的比较多,今天遇到同事不想用flash之类也不想用网上的插件,那么我给了他一种解决办法:

思路:

1. 页面上传图片的部分放到一个iframe中,iframe设置无边框无滚动条,和所嵌入的页面风格一致,根据需要设置固定大小

2. 在iframe中提交上传图片的表单,提交后再次返回原页面(iframe所指向的页面)并从服务器带回刚上传的图片地址,调用父页面的js代码加载图片

3. 如果用到要进度条等效果,就在表单提交后,在servlet一端输出进度条,然后一直发送调用js脚本,及时改变页面内容。其他功能诸如取消等功能可以参考推送

下面的代码实现了基本的文件上传:

index.jsp页面里嵌入一个文件上传的页面 _uploadpic.jsp

index.jsp:

...

 <script type="text/javascript">
 /*
param imgPath:img path of uploaded

this function will show the uploaded img in div(id=show_img_div)
 */
 function showUploadImg(imgPath){
if(imgPath=="")return;
document.getElementById("show_img_div").innerHTML="<img src='"+imgPath+"'/>";
}
 </script>
 <body>
 <iframe scrolling="no"width="300" height="100" src="_uploadpic.jsp"></iframe>
<!-- use to show img(uploaded) -->
<div id="show_img_div"></div>


...

_uploadpic.jsp:

...

<body onload="javascript:window.parent.showUploadImg('${img}');"><!--'${img}' request或者session中的图片地址(从服务器传递来的) -->
<form method="post" id="upload_form" action="${pageContext.request.contextPath }/servlet/IframeTestImageServlet" enctype="multipart/form-data">
  <input type="file" name="pic"/><br/><input type="submit" value="upload"/>
  </form> 
</body>


...

servlet:(处理图片上传的servlet)

//处理上传的图片 

.... 代码多 此处略去

   //把刚上传的图片在服务器中的地址返回到客户端

request.setAttribute("img",request.getContextPath()+"/img/mm.jpg");// '/img/mm.jpg'表示刚上传图片在服务器中的地址
request.getRequestDispatcher("/_uploadpic.jsp").forward(request, response);

以上这篇用iframe实现不刷新整个页面上传图片的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS画线(实例代码)
Nov 20 Javascript
用javascript关闭本窗口不弹出询问框的方法
Sep 12 Javascript
用Jquery.load载入页面后样式没了页面混乱的解决方法
Oct 20 Javascript
jQuery实现contains方法不区分大小写的方法
Feb 13 Javascript
举例讲解AngularJS中的模块
Jun 17 Javascript
JS Array创建及concat()split()slice()的使用方法
Jun 03 Javascript
Angular的$http与$location
Dec 26 Javascript
jQuery实现对象转为url参数的方法
Jan 11 Javascript
js+canvas实现动态吃豆人效果
Mar 22 Javascript
利用JS做网页特效_大图轮播(实例讲解)
Aug 09 Javascript
基于three.js实现的3D粒子动效实例代码
Apr 09 Javascript
JS实现灯泡开关特效
Mar 30 Javascript
Form表单按回车自动提交表单的实现方法
Nov 18 #Javascript
form+iframe解决跨域上传文件的方法
Nov 18 #Javascript
jQuery ajax 当async为false时解决同步操作失败的问题
Nov 18 #Javascript
微信小程序开发实战教程之手势解锁
Nov 18 #Javascript
JavaScript之WebSocket技术详解
Nov 18 #Javascript
仿iframe效果Aajx文件上传实例
Nov 18 #Javascript
JavaScript之cookie技术详解
Nov 18 #Javascript
You might like
用JavaScript实现仿Windows关机效果
2007/03/10 Javascript
jquery网页元素拖拽插件效果及实现
2013/08/05 Javascript
javascript浏览器兼容教程之事件处理
2014/06/09 Javascript
js中运算符&amp;&amp; 和 || 的使用记录
2014/08/21 Javascript
使用script的src实现跨域和类似ajax效果
2014/11/10 Javascript
浅谈jQuery中Ajax事件beforesend及各参数含义
2016/12/03 Javascript
关于vue.js v-bind 的一些理解和思考
2017/06/06 Javascript
vue-cli启动本地服务局域网不能访问的原因分析
2018/01/22 Javascript
vue弹窗组件的实现示例代码
2018/09/10 Javascript
vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】
2018/11/08 Javascript
微信小程序整合使用富文本编辑器的方法详解
2019/04/25 Javascript
js中!和!!的区别与用法
2020/05/09 Javascript
[01:09]DOTA2次级职业联赛 - 99战队宣传片
2014/12/01 DOTA
12步入门Python中的decorator装饰器使用方法
2016/06/20 Python
Python中顺序表的实现简单代码分享
2018/01/09 Python
使用Python制作微信跳一跳辅助
2018/01/31 Python
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
tensorflow 中对数组元素的操作方法
2018/07/27 Python
关于pytorch中网络loss传播和参数更新的理解
2019/08/20 Python
python实现移动木板小游戏
2020/10/09 Python
关于CSS Tooltips(鼠标经过时显示)的效果
2013/04/10 HTML / CSS
英国知名衬衫品牌美国网站:Charles Tyrwhitt美国
2016/08/28 全球购物
FORZIERI澳大利亚站:全球顶级奢华配饰精品店
2016/12/31 全球购物
Oroton中国官网:澳洲知名奢侈配饰品牌
2017/03/26 全球购物
怎样在程序里获得一个空指针
2015/01/24 面试题
一道输出判断型Java面试题
2014/10/01 面试题
药学专业毕业生求职信
2013/10/20 职场文书
初中女生自我鉴定
2013/12/19 职场文书
药品业务员岗位职责
2014/04/17 职场文书
个人综合鉴定材料
2014/05/23 职场文书
小学综合实践活动总结
2014/07/07 职场文书
企业办公室主任岗位职责
2015/04/01 职场文书
企业工会工作总结2015
2015/05/13 职场文书
pycharm无法导入lxml的解决办法
2021/03/31 Python
golang gopm get -g -v 无法获取第三方库的解决方案
2021/05/05 Golang
JS封装cavans多种滤镜组件
2022/02/15 Javascript