使用ajax实现文件上传,使用input实现本地图片展示

使用ajax实现文件上传,使用input实现本地图片展示

一、实现本地图片预览

HTML:

<input type="file" id="chooseImage" name="myfile"  value="" class="layui-btn">
<!-- 保存用户自定义的背景图片 -->
<img style="width: 150px;height: 150px;display: none" id="cropedBigImg" value='custom' alt="lorem ipsum dolor sit" data-address='' title="自定义背景"/>

JS:(使用JQuery)

    $(function (){
        $('#chooseImage').on('change',function(){
            if ($(this)[0].files[0]==null){
                $('#cropedBigImg').css("display","none");
            }else {
                var filePath = $(this).val(),         //获取到input的value,里面是文件的路径
                    fileFormat = filePath.substring(filePath.lastIndexOf(".")).toLowerCase(),
                    src = window.URL.createObjectURL(this.files[0]); //转成可以在本地预览的格式

                // 检查是否是图片
                if( !fileFormat.match(/.png|.jpg|.jpeg/) ) {
                    $('#cropedBigImg').css("display","none");
                    error_prompt_alert('上传错误,文件格式必须为:png/jpg/jpeg');
                    return;
                }

                // $('#cropedBigImg').attr('src',src);
                $('#cropedBigImg').attr('src',src).css("display","inline-block");
            }
        });
    })

样式展示:

在这里插入图片描述

二、AJAX上传文件

关键代码:

var formData = new FormData();
formData.append("myfile", $("#chooseImage")[0].files[0]);

//ajax参数:
 $.ajax({
                    type: "post",
                    url: "/index/reviseAdminInfo",
                    data: formData,
                    cache: false, //上传文件不需要缓存
                    processData: false, // 告诉jQuery不要去处理发送的数据
                    contentType: false, // 告诉jQuery不要去设置Content-Type请求头
                    success: function(data){
                    }
     )}

全部代码:

                var formData = new FormData();
                if($("#chooseImage")[0].files[0]!=null){
                    formData.append("myfile", $("#chooseImage")[0].files[0]);
                }
                formData.append("adminUserName",data.field.adminUserName);
                formData.append("adminPassword",data.field.adminPassword);
                formData.append("adminId",data.field.adminId);
                $.ajax({
                    type: "post",
                    url: "/index/reviseAdminInfo",
                    data: formData,
                    cache: false, //上传文件不需要缓存
                    processData: false, // 告诉jQuery不要去处理发送的数据
                    contentType: false, // 告诉jQuery不要去设置Content-Type请求头
                    success: function(data){
                        console.log(data==="1")
                        if (data==="1"){
                            layer.msg("修改成功",{
                                icon: 1,
                                time: 1500 //2秒关闭(如果不配置,默认是3秒)
                            },function (){
                                miniTab.deleteCurrentByIframe();
                            })
                        }else {
                            layer.msg("修改失败",{
                                icon: 2,
                                time: 2000 //2秒关闭(如果不配置,默认是3秒)
                            })
                        }
                    },
                    error: function (){
                        layer.msg("修改失败",{
                            icon: 2,
                            time: 2000 //2秒关闭(如果不配置,默认是3秒)
                        })
                    }
                });
                    time: 2000 //2秒关闭(如果不配置,默认是3秒)
                        })
                    }
                });
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我认不到你

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值