vant提交图片的时候,前端压缩图片

本文介绍了一种利用HTML5的Canvas元素进行图片处理的方法。具体步骤包括:加载图片到Canvas上,调整尺寸并裁切,最后将Canvas的内容转换回图片格式以便进一步使用或上传。该方法适用于需要对用户上传的图片进行预处理的应用场景。

主要是使用canvas将图片画出来然后裁切好,最后将canvas的图转成图片

HTML代码

<van-uploader max-size="5242880" :after-read="afterRead"  v-model="picList" multiple deletable  upload-text="222222"/>

JS代码

afterRead(file){
        console.log(file,'0000')
        this.face = [];
        let canvas = document.createElement('canvas') // 创建Canvas对象(画布)
        let context = canvas.getContext('2d')
        let img = new Image()
        img.src = file.content // 指定图片的DataURL(图片的base64编码数据)
        img.onload = () => {
          canvas.width = img.width/2
          canvas.height = img.height/2
          context.drawImage(img, 0, 0, img.width/2, img.height/2)
          file.content = canvas.toDataURL(file.file.type, 0.92) // 0.92为默认压缩质量

        }
        console.log(this.picList,'222222222222222222222222222222')
      },

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值