用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 相关文章推荐
URL编码转换,escape() encodeURI() encodeURIComponent()
Dec 27 Javascript
Prototype Class对象学习
Jul 19 Javascript
javascript 通用简单的table选项卡实现
May 07 Javascript
JS获取月份最后天数、最大天数与某日周数的方法
Dec 08 Javascript
Javascript基础回顾之(一) 类型
Jan 31 Javascript
angular.js指令中transclude选项及ng-transclude指令详解
May 24 Javascript
微信小程序多张图片上传功能
Jun 07 Javascript
vue-cli2.9.3 详细教程
Apr 23 Javascript
Node.js使用supervisor进行开发中调试的方法
Mar 26 Javascript
angular使用md5,CryptoJS des加密的方法
Jun 03 Javascript
jquery向后台提交数组的代码分析
Feb 20 jQuery
vue 监听窗口变化对页面部分元素重新渲染操作
Jul 28 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
如何把PHP转成EXE文件
2006/10/09 PHP
PHP实现格式化文件数据大小显示的方法
2015/01/03 PHP
php递归删除目录与文件的方法
2015/01/30 PHP
PHP中SQL查询语句的id=%d解释(推荐)
2016/12/10 PHP
PHP实现单例模式建立数据库连接的方法分析
2020/02/11 PHP
combox改进版 页面原型参考dojo的,比网上jQuery的那些combox功能强,代码更小
2010/04/15 Javascript
前端必备神器 Snap.svg 弹动效果
2014/11/10 Javascript
JavaScript仿静态分页实现方法
2015/08/04 Javascript
程序员必知35个jQuery 代码片段
2015/11/05 Javascript
getElementById().innerHTML与getElementById().value的区别
2016/10/27 Javascript
jQuery对table表格进行增删改查
2020/12/22 Javascript
JavaScript 详解预编译原理
2017/01/22 Javascript
基于JavaScript实现轮播图原理及示例
2020/04/10 Javascript
vue学习笔记之作用域插槽实例分析
2020/02/01 Javascript
JS访问对象两种方式区别解析
2020/08/29 Javascript
[42:50]NB vs VP 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
[01:36]极致酷炫!TI9典藏宝瓶+撼地者至宝展示
2019/06/11 DOTA
python类继承与子类实例初始化用法分析
2015/04/17 Python
python常见数制转换实例分析
2015/05/09 Python
python3+PyQt5实现自定义分数滑块部件
2018/04/24 Python
numpy.random模块用法总结
2019/05/27 Python
python通过TimedRotatingFileHandler按时间切割日志
2019/07/17 Python
python db类用法说明
2020/07/07 Python
通过实例了解python__slots__使用方法
2020/09/14 Python
如何Tkinter模块编写Python图形界面
2020/10/14 Python
Python APScheduler执行使用方法详解
2020/12/10 Python
美国体育用品商店:Rally House(NCAA、NFL、MLB、NBA、NHL和MLS)
2018/01/03 全球购物
养殖人员的创业计划书范文
2013/12/26 职场文书
财务会计专业个人求职信范本
2014/01/08 职场文书
厨师个人自我鉴定范文
2014/04/19 职场文书
物业保安岗位职责
2014/07/02 职场文书
党员自我评价范文2015
2015/03/03 职场文书
Vue CLI中模式与环境变量的深入详解
2021/05/30 Vue.js
利用Python判断你的密码难度等级
2021/06/02 Python
mysql 排序失效
2022/05/20 MySQL
js作用域及作用域链工作引擎
2022/07/07 Javascript