vant van-uploader组件实现点击图片进行编辑(更换图片)

本文介绍了如何使用Vue的van-uploader组件创建两个样式一致但功能各异的图片上传器。组件1用于触发图片选取并传递数据到组件2,而组件2展示已选取图片。通过v-model和after-read事件,实现了图片的无缝切换和数据管理。
摘要由CSDN通过智能技术生成

示例图:

在这里插入图片描述
思路:
1.写两个uploader组件,确保他们样式一样,定位将他们重叠放在同一个位置。给其中一个uploader组件设置z-index,让她位于上方(以下称为组件1),组件1用于触发选取图片的方法,组件2用于展示选取好的图片

2.为组件1使用v-model绑定fileList1,用于存储选取的图片信息,再使用after-read属性绑定一个读取图片成功后会触发的方法ClickFile;同理,为组件2使用v-model绑定fileImg,组件2不需要任何的方法

3.点击组件1,选取图片成功后,触发ClickFile,在ClickFile中将fileList1赋值给fileImg,并清空fileList(赋值成空数组,保证组件1内不显示图片),这样组件1内依旧是空的,还可以触发选取图片的方法,而组件2,已经存储了组件1的数据。

代码:
html

<div class="uploadBox">
   <p>
      附件照片
      <span v-if="!ImgData">(未添加,点击添加)</span>
      <span v-if="ImgData">(已添加,点击编辑)</span>
   </p>
   <div class="uploadImg">
      <van-uploader v-model="fileImg" multiple :max-count="1" :deletable="false" :preview-full-image="false">
         <van-button icon="plus" type="primary">添加照片</van-button>
      </van-uploader>
   </div>
   <div class="uploadImg" style="z-index:99">
       <van-uploader v-model="fileList" multiple :max-count="1" :deletable="false" :preview-full-image="false"
            :after-read="ClickFile">
         <van-button type="primary"></van-button>
       </van-uploader>
   </div>
</div>

script

// 文件上传
 let fileImg = ref([])
 let fileList = ref([]);
 let ClickFile = (file) => {
	 fileImg.value = fileList.value
	 fileList.value = []
 }

style

.uploadBox {
  position: relative;
  height: 150px;

  .uploadImg {
    position: absolute;
    left: 0px;
    top: 40px;
    width: 100%;
    height: 100px;

    img {
      width: 100%;
      height: 100%;
    }
  }
}

:deep(.van-uploader) {
  width: 100%;
  height: 100px;

  .van-uploader__wrapper {
    display: block;
    height: 100%;
  }

  .van-uploader__file {
    display: none;
  }

  .van-uploader__preview {
    height: 100%;
    margin: 0px;

    .van-uploader__preview-image {
      width: 100%;
      height: 100%;

      img {
        width: 100%;
        height: 100%;
      }
    }
  }

  .van-uploader__input-wrapper {
    height: 100%;

    .van-button--primary {
      width: 100%;
      height: 100%;
      border: 1px solid #EEEEEE;
      background: none;
      color: #427CE8;
    }
  }
}
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组件可以轻松实现头像图片上传功能,同时也可以根据需求进行个性化的定制和扩展,是一个非常实用且易于使用的组件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值