上传另一张照片后如何插入新的图片网址?

时间:2019-12-12 07:55:03

标签: vue.js antd cropperjs

我有一个Vue应用程序,其中包含具有裁剪功能的图像上传器。成功上传并裁剪了图片并取回了裁剪后的图片网址。 但是问题是当用户需要重新上传其图像时,画布仍显示旧图像。用户取消并重新上传图片时也会发生这种情况。

<template>


<div>
    <a-row :gutter="16">
      <a-col :span="12">
        <img ref="image" :src="initialImage">
      </a-col>
      <a-col :span="12" align="center">
        <p><strong>Preview</strong></p>
        <img :src="updatedImage" class="preview-image">
      </a-col>
    </a-row><br />
    <a-row :gutter="16">
      <a-button type="primary" style="float: right;" @click="crop">Crop</a-button>
      <a-button style="float: right; margin-right: 5px;" @click="cancel">Cancel</a-button>
    </a-row>
  </div>
</template>

<script>
import Cropper from 'cropperjs';

export default {
  name: 'PostCropper',
  props: {
    uploadedImage: String,
  },
  data() {
    return {
      cropper: {},
      updatedImage: {},
      image: {},
      initialImage: this.uploadedImage,
    };
  },
  methods: {
    crop() {
      this.$emit('update-image', this.updatedImage);
    },
    cancel() {
      this.$emit('cancel-upload');
    },
  },
  mounted() {
    this.image = this.$refs.image;
    this.cropper = new Cropper(this.image, {
      zoomable: false,
      scalable: false,
      aspectRatio: 1,
      crop: () => {
        const canvas = this.cropper.getCroppedCanvas();
        this.updatedImage = canvas.toDataURL('image/png');
      },
    });
  },
};
</script>

<style scoped>
  .preview-image {
    border-radius: 100px;
    width:150px;
    height:150px;
  }
</style>

我尝试用空字符串设置initialImage和updatedImage,但仍然无法正常工作。取消或继续裁剪图像后,我应该重新初始化什么?还是有另一种方法可以克服这个问题?

0 个答案:

没有答案