用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 相关文章推荐
JavaScript显示当然日期和时间即年月日星期和时间
Oct 29 Javascript
jQuery表格插件datatables用法总结
Sep 05 Javascript
jQuery实现仿路边灯箱广告图片轮播效果
Apr 15 Javascript
js实现iframe框架取值的方法(兼容IE,firefox,chrome等)
Nov 26 Javascript
AngularJS指令中的绑定策略实例分析
Dec 14 Javascript
angularjs实现多张图片上传并预览功能
Feb 24 Javascript
vue-cli单页应用改成多页应用配置详解
Jul 14 Javascript
jQuery实现点击自身以外区域关闭弹出层功能完整示例【改进版】
Jul 31 jQuery
微信小程序CSS3动画下拉菜单效果
Nov 04 Javascript
jQuery实现获取当前鼠标位置并输出功能示例
Jan 05 jQuery
微信小程序的开发范式BeautyWe.js入门详解
Jul 10 Javascript
Node.js设置定时任务之node-schedule模块的使用详解
Apr 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笔记之:有规律大文件的读取与写入的分析
2013/04/26 PHP
PHP扩展CURL的用法详解
2014/06/20 PHP
用JavaScript实现单继承和多继承的简单方法
2009/03/29 Javascript
Javascript变量作用域详解
2013/12/06 Javascript
用jquery模仿的a的title属性的例子
2014/10/22 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
2015/01/06 Javascript
jquery表单插件Autotab使用方法详解
2016/06/24 Javascript
AngularJS 应用身份认证的技巧总结
2016/11/07 Javascript
jQuery延迟执行的实现方法
2016/12/21 Javascript
详解js产生对象的3种基本方式(工厂模式,构造函数模式,原型模式)
2017/01/09 Javascript
js实现会跳动的日历效果(完整实例)
2017/10/18 Javascript
Vue-不允许嵌套式的渲染方法
2018/09/13 Javascript
Vue创建头部组件示例代码详解
2018/10/23 Javascript
Angular PWA使用的Demo示例
2019/01/31 Javascript
nodejs实现用户登录路由功能
2019/05/22 NodeJs
python获得两个数组交集、并集、差集的方法
2015/03/27 Python
Python中用Spark模块的使用教程
2015/04/13 Python
使用Python编写简单的画图板程序的示例教程
2015/12/08 Python
Python中单例模式总结
2018/02/20 Python
flask-socketio实现WebSocket的方法
2018/07/31 Python
使用Python3内置文档高效学习以及官方中文文档
2019/05/19 Python
利用python实现.dcm格式图像转为.jpg格式
2020/01/13 Python
Python如何使用队列方式实现多线程爬虫
2020/05/12 Python
Python远程方法调用实现过程解析
2020/07/28 Python
Python数据可视化常用4大绘图库原理详解
2020/10/23 Python
CSS3之多背景background使用示例
2013/10/18 HTML / CSS
css3利用transform变形结合事件完成扇形导航
2020/10/26 HTML / CSS
佛罗里达州印第安河新鲜水果:Hale Groves
2017/02/20 全球购物
户外亲子活动策划方案
2014/02/07 职场文书
六个一活动实施方案
2014/03/21 职场文书
三问三解心得体会
2014/09/05 职场文书
党的群众路线整改落实情况汇报
2014/10/28 职场文书
2015年小学生新年寄语
2014/12/08 职场文书
党员自我评价2015
2015/03/03 职场文书
让人感觉高大上的讲话稿怎么写?
2019/07/08 职场文书
一文搞懂Python Sklearn库使用
2021/08/23 Python