vant3之van-uploader 图片上传时限制上传文件类型、文件大小、图片的宽高

3 篇文章 0 订阅
3 篇文章 0 订阅

我写技术文章没那么多废话,直接上代码:
1.在html里:
max-count是限制上传的数量
accept是限制上传文件的类型

   <van-field name="Files" label="照片" >
       <template #input>
          <van-uploader :max-count="1" accept='.jpg,.jpeg,.png'  v-model="data.photoUrl" :before-read="beforeRead"  :after-read="afterRead"  @delete="deleteFiles"/>
      </template>
  </van-field>

2.在ts里:
我是在before-read里限制上传文件类型、上传文件大小、图片的宽高

//(boolean | undefined | Promise<File | File[] | undefined>) 这个是防止:before-read报红
const beforeRead = (file:any, detail:any) : (boolean | undefined | Promise<File | File[] | undefined>) => {
    console.log("上传前",file);
    const imgformat = /image\/(png|jpg|jpeg)$/;
    if (!imgformat.test(file.type)) {
        Toast.fail('请上传 jpg/jpeg/png 格式图片');
        return false;
    }
    if (file.size > 5 * 1024 * 1024) {
        Toast.fail('文件大小不能超过 5M');
        return false;
    }
    return new Promise((resolve) => {
    //用这种方式是因为用到了vant3推荐的Compressor 
        Promise.all([checkWidthAndHeight(file)]).then(res => {
            return new proxy.Compressor (file, {
                success: resolve
            })
        })
    })
    
};
//检查图片的宽高
const checkWidthAndHeight = (file:any) => {
    return new Promise((resolve,reject) => {
        var img = new Image();
        img.src = URL.createObjectURL(file);
        img.onload = function () {
            var width = img.width;
            var height = img.height;
            console.log("当前图片的宽高", width, height);
            if (width > 500 || height > 695) {
                Toast.fail('图片分辨率不能超过 500 X 695'); // 图片分辨率不能超过 500 X 695
                reject(false);
            }else{
                resolve(true);
            }
        }
    })
}
//删除头像
const deleteFiles = (file: any, detail: any): void => {
    console.log("删除数据",file,detail);
}

3.感谢
如果觉得写得好,记得收藏哦 ~ (O_O) ~

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
Vue Vant-UI是Vue.js的一个移动端UI组件库,是一个轻量级的、效的组件库,非常适合用于移动端前端开发。其中,Van-UploaderVant-UI的上传文件组件,允许用户将文件上传到服务器或第三方存储库。 在实现头像图片上传,我们可以采用如下步骤: 1. 首先需要安装Vant-UI组件库。可以通过npm命令进行安装,输入如下代码:npm install vant --save 2. 在Vue项目中引入Vant-UI组件库。在main.js文件中写入如下代码:import Vant from 'vant' import 'vant/lib/vant-css/index.css' Vue.use(Vant) 3. 在需要使用上传头像的组件中引入Van-Uploader组件,并编写如下代码: <template> <van-uploader :show-upload="false" :before-read="beforeRead" :after-read="afterRead" > <van-icon name="photograph" /> </van-uploader> </template> <script> export default { data() { return { file: '' } }, methods: { beforeRead(file) { if (file.type !== 'image/jpeg' && file.type !== 'image/png') { this.$toast('请上传 JPG/PNG 格式的图片'); return false; } if (file.size > 500 * 1024) { this.$toast('图片大小不能超过 500KB'); return false; } }, afterRead(file) { this.file = URL.createObjectURL(file.file); } } } </script> 4. 上面的代码中,我们主要使用了Van-Uploader组件的before-read和after-read两个事件回调函数。before-read为上传文件之前的校验函数,例如判断文件类型文件大小是否符合要求,这里我们限制了文件类型为JPG/PNG并且大小不能超过500KB。after-read则表示读取文件后的回调函数,我们将上传的文件读取为本地链接并保存到file属性中,以便进行后续处理。 5. 最后,将file属性传递给后端进行处理,例如将该链接保存到服务器或者上传到第三方存储库中。 总之,使用Van-Uploader组件可以轻松实现头像图片上传功能,同也可以根据需求进行个性化的定制和扩展,是一个非常实用且易于使用的组件。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值