JavaScript实现图片上传并预览并提交ajax


Posted in Javascript onSeptember 30, 2019

本文实例为大家分享了JavaScript实现图片上传并预览并提交ajax的具体代码,供大家参考,具体内容如下

图片上传并预览

JavaScript实现图片上传并预览并提交ajax

HTML

<div class="file-box">
 <img id="preview" />
 <input type="text" id="imgfield" class="txt" placeholder="预览">
 <input type="file" name="file" id = "input_file" accept="image/gif,image/jpeg,image/jpg,image/png,image/svg" "imgPreview(this)" > 
</div>

css

.file-box {
 position: relative;
 display: inline-block;
}
.file-box img {
 width: 50px;
 height: 50px;
 border-radius: 50%;
 position: absolute;
 top: -30px;
 left: 0;
 display: inline-block;
 border: none;
}
.file-box .txt,.file-box .file {
 width: 70px;
 height: 36px;
 position: absolute;
 top: -20px;
 left: 100px;
 text-align: center;
}

JS

function imgPreview(fileDom) {
 //判断是否支持FileReader
 if(window.FileReader) {
 var reader = new FileReader();
 } else {
 alert("您的设备不支持图片预览功能,如需该功能请升级您的设备!");
 }
 //获取文件
 var file = fileDom.files[0];
 var imageType = /^image\//;
 //是否是图片
 if(!imageType.test(file.type)) {
 alert("请选择图片!");
 return;
 }
 //读取完成
 reader.onload = function(e) {
 //获取图片dom
 var img = document.getElementById("preview");
 //图片路径设置为读取的图片
 img.src = e.target.result;
 };
 reader.readAsDataURL(file);
}

上传图片提交ajax

如果想把图片信息通过ajax传给后端,则需要通过new FormData() 上传图片信息,然后使用 append() 方法向该对象里添加字段,具体代码如下:

(注:以下代码在图片预览成功后执行,也就是在reader.readAsDataURL(file); 后)

var formData = new FormData(); 
formData.append('file', $('#input_file')[0].files[0]); //添加图片信息的参数
formData.append('sizeid',123); //添加其他参数
$.ajax({
 url: '/material/uploadFile',
 type: 'POST',
 cache: false, //上传文件不需要缓存
 data: formData,
 processData: false, // 告诉jQuery不要去处理发送的数据
 contentType: false, // 告诉jQuery不要去设置Content-Type请求头
 success: function (data) {
 var rs = eval("("+data+")");
 if(rs.state==1){
 tipTopShow('上传成功!');
 }else{
 tipTopShow(rs.msg);
 }
 },
 error: function (data) {
 tipTopShow("上传失败");
 }
})

JavaScript实现图片上传并预览并提交ajax

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript各浏览器中option元素的表现差异
Apr 07 Javascript
node.js中的fs.truncateSync方法使用说明
Dec 15 Javascript
jQuery实现仿Alipay支付宝首页全屏焦点图切换特效
May 04 Javascript
jQuery+CSS3折叠卡片式下拉列表框实现效果
Nov 02 Javascript
全面解析Bootstrap表单使用方法(表单样式)
Nov 24 Javascript
基于javascript实现泡泡大冒险网页版小游戏
Mar 23 Javascript
[原创]Bootstrap 中下拉菜单修改成鼠标悬停直接显示
Apr 14 Javascript
canvas绘制万花筒效果(代码分享)
Jan 20 Javascript
three.js实现3D模型展示的示例代码
Dec 31 Javascript
使用vue-cli脚手架工具搭建vue-webpack项目
Jan 14 Javascript
js 下拉菜单点击旁边收起实现(踩坑记)
Sep 29 Javascript
解决qrcode.js生成二维码时必须定义一个空div的问题
Jul 09 Javascript
浅探express路由和中间件的实现
Sep 30 #Javascript
JavaScript实现单图片上传并预览功能
Sep 30 #Javascript
解决vue cli使用typescript后打包巨慢的问题
Sep 30 #Javascript
laravel实现中文和英语互相切换的例子
Sep 30 #Javascript
JavaScript键盘事件响应顺序详解
Sep 30 #Javascript
vue自动化路由的实现代码
Sep 30 #Javascript
js实现图片上传即时显示效果
Sep 30 #Javascript
You might like
使用PHP会话(Session)实现用户登陆功能
2013/06/29 PHP
WordPress中重置文章循环的rewind_posts()函数讲解
2016/01/11 PHP
ThinkPHP 整合Bootstrap Ajax分页样式
2016/12/23 PHP
深入理解PHP+Mysql分布式事务与解决方案
2020/12/03 PHP
[IE&amp;FireFox兼容]JS对select操作
2007/01/07 Javascript
基于jQuery的输入框无值自动显示指定数据的实现代码
2011/01/24 Javascript
调整小数的格式保留小数点后两位
2014/05/14 Javascript
JS上传图片预览插件制作(兼容到IE6)
2016/08/07 Javascript
微信小程序 HTTPS报错整理常见问题及解决方案
2016/12/14 Javascript
Bootstrap学习笔记之进度条、媒体对象实例详解
2017/03/09 Javascript
nodejs批量下载图片的实现方法
2017/05/19 NodeJs
vue loadmore组件上拉加载更多功能示例代码
2017/07/19 Javascript
node基于puppeteer模拟登录抓取页面的实现
2018/05/09 Javascript
基于vue框架手写一个notify插件实现通知功能的方法
2019/03/31 Javascript
node删除、复制文件或文件夹示例代码
2019/08/13 Javascript
简单总结Python中序列与字典的相同和不同之处
2016/01/19 Python
Python进阶篇之字典操作总结
2016/11/16 Python
python利用标准库如何获取本地IP示例详解
2017/11/01 Python
TensorFlow高效读取数据的方法示例
2018/02/06 Python
Flask之flask-session的具体使用
2018/07/26 Python
python networkx 根据图的权重画图实现
2019/07/10 Python
如何基于Python按行合并两个txt
2020/11/03 Python
Evisu官方网站:日本牛仔品牌,时尚街头设计风格
2016/12/30 全球购物
英国地毯卖家:The Rug Seller
2019/07/18 全球购物
C#笔试题
2015/07/14 面试题
农药学硕士毕业生自荐信
2013/09/25 职场文书
成人大专自我鉴定范文
2013/10/19 职场文书
2014全国两会学习心得体会1000字
2014/03/10 职场文书
党课知识竞赛主持词
2014/04/01 职场文书
高中教师考核方案
2014/05/18 职场文书
个人合伙协议书范本
2014/10/14 职场文书
大学生操行评语大全
2014/12/31 职场文书
幼儿园中班教师个人工作总结
2015/02/06 职场文书
2015年法律事务部工作总结
2015/07/27 职场文书
JS不要再到处使用绝对等于运算符了
2021/04/30 Javascript
MySQL 表空间碎片的概念及相关问题解决
2021/05/07 MySQL