最简单的js实现上传头像并正常回显

既然有上传头像功能,那用户肯定得选择完照片后显示出来,

废话不多说,下面就是提供一段简单的代码来实现,希望对大家也有帮助;

h5 部分

 <!--头像-->
    <div class="head-p" id="touxiang">
         <img  src="/img/user_pic_big.jpg" alt='头像'  width="100" height="100" id="avatar_img">
    </div>
    <div  id="fromTx">
         <input type="file" class="file"  name="avatar" id="avatar">
    </div>

js让图片显示方式

// 头像预览
$("#avatar").change(function () {
    //拿到文件数据
    var choose_file = $(this)[0].files[0];
    //截取图片名称小数点后的字符串
    var ftype=choose_file.name.substring(choose_file.name.lastIndexOf(".")+1);
    //校验格式是否是图片类型
    if(ftype=="jpg" || ftype=="png" || ftype=="jpeg" || ftype == "JPG"){
        //限制大小,照片大小不能超过1M
        var size = choose_file.size / 1024 / 1024;
        if (size > 1) {
            alert("头像不能大于1M");
            return false;
        }
    // 实例化一个阅读器对象
    var reader = new FileReader();
    // 读取文件的路径,没有返回值,结果在reader.result里
    reader.readAsDataURL(choose_file);
    // 读取需要时间,读完后再修改图片路径
    reader.onload=function () {
        //回显给上方图片中
        $("#avatar_img").attr("src",this.result); 
    }
    }else{
        alert("头像格式不对,请重新选择!");
        return false;
    }
});

代码就这么简单,如有问题请留言一起讨论~

  • 9
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值