element 实现上传单个图片功能(上传一张图片后隐藏上传按钮功能)完整demo供参考

<!-- demo 上传单个图片-->
<template>
  <div>
    <h2 style="margin-bottom:10px">上传单个图片</h2>
    <el-upload
        class="avatar-uploader"
        action="https://jsonplaceholder.typicode.com/posts/"
        list-type="picture-card"
        :on-preview="handlePictureCardPreview"
        :on-remove="handleRemove"
        :http-request="httpRequest"
        :class="{'demo-httpRequestImg':httpRequestImg}"
        >
        <i class="el-icon-plus"></i>
    </el-upload>
    <el-dialog :visible.sync="dialogVisibleImg" append-to-body class="ImgClass">
        <img width="100%" :src="dialogImageUrl" alt="">
    </el-dialog>
  </div>
</template>

<script>
export default {
  data(){
    return{
      dialogImageUrl: '',//预览url
      dialogVisibleImg:false,
      httpRequestImg:false,//展示单个图片
    }
  },
  methods:{
    httpRequest(a) { //上传成功
      this.httpRequestImg = true;
    },
    handlePictureCardPreview(file) { //预览
      this.dialogImageUrl = file.url;
      this.dialogVisibleImg = true;
    },
    handleRemove(file, fileList) { //删除
      this.httpRequestImg = false;
      console.log(file, fileList);
    },
  }
}
</script>

<style lang="scss" scoped>
  .demo-httpRequestImg{
    /deep/ .el-upload--picture-card{
        display: none;
    }
  } 
</style>

 

好的,针对您的问题,我可以提供以下代码示例,用于实现Vue的Element UI Upload组件上传单个图片并带删除和放大功能: HTML模板代码: ``` <template> <div> <el-upload class="upload-demo" action="/your-upload-api" :before-upload="beforeUpload" :on-success="onSuccess" :on-error="onError" :show-file-list="false" > <div v-if="!imageUrl" class="upload-plus"> <i class="el-icon-plus"></i> <div class="upload-text">上传图片</div> </div> <div v-else class="upload-success"> <img :src="imageUrl" alt="uploaded image"> <div class="upload-actions"> <span class="upload-delete" @click="deleteImage">删除图片</span> <span class="upload-enlarge" @click="enlargeImage">放大图片</span> </div> </div> </el-upload> </div> </template> ``` Vue组件代码: ``` <script> export default { data() { return { imageUrl: '' } }, methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' || file.type === 'image/png' if (!isJPG) { this.$message.error('上传图片只能是 JPG 或 PNG 格式!') return false } const isLt2M = file.size / 1024 / 1024 < 2 if (!isLt2M) { this.$message.error('上传图片大小不能超过 2MB!') return false } }, onSuccess(response) { this.imageUrl = response.data.url }, onError(error) { this.$message.error('上传图片失败!') }, deleteImage() { this.imageUrl = '' }, enlargeImage() { this.$alert(`<img src="${this.imageUrl}" style="max-width: 100%;">`, '放大图片', { dangerouslyUseHTMLString: true }) } } } </script> ``` 在该示例中,我们使用了Vue的Element UI Upload组件来实现图片上传功能。我们通过`before-upload`钩子函数来限制上传图片的格式和大小。在上传成功时,我们将返回的图片URL赋值给`imageUrl`属性,以便在页面上显示上传图片。我们还使用了一个删除按钮和一个放大按钮,分别用于删除和放大图片。当用户点击放大按钮时,我们使用`$alert`方法来展示放大后的图片
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值