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 相关文章推荐
jquery+ajax每秒向后台发送请求数据然后返回页面的代码
Jan 17 Javascript
在jQuery ajax中按钮button和submit的区别分析
Oct 07 Javascript
jquery实现侧边弹出的垂直导航
Dec 09 Javascript
JavaScript实现图片DIV竖向滑动的方法
Apr 25 Javascript
jQuery中extend()和fn.extend()方法详解
Jun 03 Javascript
jQuery中的each()详细介绍(推荐)
May 25 Javascript
完美解决jQuery符号$与其他javascript 库、框架冲突的问题
Aug 09 Javascript
微信小程序 页面跳转传参详解
Oct 28 Javascript
JS如何判断浏览器类型和详细区分IE各版本浏览器
Mar 04 Javascript
详解Angular2中Input和Output用法及示例
May 21 Javascript
前端防止用户重复提交js实现代码示例
Sep 07 Javascript
详解Vue Elementui中的Tag与页面其它元素相互交互的两三事
Sep 25 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上传apk后自动提取apk包信息的使用(示例下载)
2013/04/26 PHP
PHP中比较两个字符串找出第一个不同字符位置例子
2014/04/08 PHP
php+mysql+jquery实现日历签到功能
2017/02/27 PHP
jquery插件之easing使用
2010/08/19 Javascript
jquery命令汇总,方便使用jquery的朋友
2012/06/26 Javascript
jQuery Tools tab(幻灯片)
2012/07/14 Javascript
文本框中禁止非数字字符输入比如手机号码、邮编
2013/08/19 Javascript
js实现下拉框选择要显示图片的方法
2015/02/16 Javascript
Vuex之理解state的用法实例
2017/04/19 Javascript
Vue resource中的GET与POST请求的实例代码
2017/07/21 Javascript
2种简单的js倒计时方式
2017/10/20 Javascript
VeeValidate在vue项目里表单校验应用案例
2018/05/09 Javascript
layer弹出层父子页面事件相互调用方法
2018/08/17 Javascript
JavaScript使用表单元素验证表单的示例代码
2019/08/20 Javascript
JavaScript函数重载操作实例浅析
2020/05/02 Javascript
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
python插入排序算法实例分析
2015/07/03 Python
python实现人民币大写转换
2018/06/20 Python
漂亮的Django Markdown富文本app插件的实现
2019/01/02 Python
Python XML转Json之XML2Dict的使用方法
2019/01/15 Python
Python使用numpy模块实现矩阵和列表的连接操作方法
2019/06/26 Python
Python3enumrate和range对比及示例详解
2019/07/13 Python
给你一面国旗 教你用python画中国国旗
2019/09/24 Python
通过实例简单了解Python中yield的作用
2019/12/11 Python
Python跑循环时内存泄露的解决方法
2020/01/13 Python
解决Tensorflow占用GPU显存问题
2020/02/03 Python
Python单元测试及unittest框架用法实例解析
2020/07/09 Python
Python中return函数返回值实例用法
2020/11/19 Python
45个非常奇妙的CSS3 特性应用示例
2012/01/01 HTML / CSS
限量版运动鞋和街头服饰:TheDrop
2020/09/06 全球购物
自动化专业本科毕业生求职信
2013/10/20 职场文书
运动会致辞稿50字
2014/02/04 职场文书
如何书写民事调解协议书?
2019/06/25 职场文书
如何用JavaScript实现一个数组惰性求值库
2021/05/05 Javascript
redis实现共同好友的思路详解
2021/05/26 Redis
唤醒紫霞仙子,携手再游三界!大话手游X《大话西游》电影合作专属剧情任务
2022/04/03 其他游戏