Vue image cropping component example code

Vue image cropping component example code

Example:

tip: This component is based on vue-cropper secondary packaging

Install the plugin

npm install vue-cropper

yarn add vue-cropper

Write packaged components

<!-- Simple image cropping component--- Secondary packaging-->
<!-- More APIs https://github.com/xyxiao001/vue-cropper -->
<!-- Usage: Pass in the image ratio to display or hide. Method: Listen for the bottom button click --- add more props query documents yourself -->

<template>
  <div v-if="value" :value="value" @input="val => $emit('input', val)" class="conbox">
    <div class="info">
      <vueCropper
        ref="cropper"
        :img="img"
        :outputSize="outputSize"
        :outputType="outputType"
        :info="info"
        :canScale="canScale"
        :autoCrop="autoCrop"
        :fixed="fixed"
        :fixedNumber="fixedNumber"
        :full="full"
        :fixedBox="fixedBox"
        :canMove="canMove"
        :canMoveBox="canMoveBox"
        :original="original"
        :centerBox="centerBox"
        :infoTrue="infoTrue"
        :mode="mode"
      ></vueCropper>
    </div>
    <div class="btns">
      <div @click="clickCancelCut" class="cancel">Cancel</div>
      <img @click="clickRotate" src="../../assets/paradise/rotate.png" alt="" />
      <div @click="clickOk" class="okey">OK</div>
    </div>
  </div>
</template>

<script>
import { VueCropper } from 'vue-cropper';
export default {
  name: 'PictureCropping',
  components: { VueCropper },
  props: {
    value: {
      type: Boolean,
      default: false,
    },
    //Crop the image address img: {
      type: String,
      default: '',
    },
    //The aspect ratio of the screenshot frame fixedNumber: {
      type: Array,
      default: () => {
        return [1, 1];
      },
    },
  },
  data() {
    return {
      // Basic configuration option for the cropping component
      : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : :
  },
  computed: {},
  watch: {},
  //Life cycle - creation completed (access the current this instance)
  created() {},
  //Life cycle - Mounting completed (accessing DOM elements)
  mounted() {},
  methods: {
    clickCancelCut() {
      this.$emit('clickCancelCut', 'Click to cancel');
      this.$refs.cropper.stopCrop();
      this.$refs.cropper.clearCrop();
    },
    clickRotate() {
      this.$refs.cropper.rotateRight();
      this.$emit('clickRotate', 'Click to rotate');
    },
    clickOk() {
      //Output the trimmed base64
      this.$refs.cropper.getCropData(data => {
        this.$emit('clickOk', data);
        this.$refs.cropper.stopCrop();
        this.$refs.cropper.clearCrop();
      });
    },
  },
};
</script>
<style lang='less' scoped>
/* @import url(); Import css class*/
.conbox {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  box-sizing: border-box;
  height: 100vh;
  width: 100%;
  background-color: #000;
  display: flex;
  flex-direction: column;
  justify-content: center;
  .info {
    width: auto;
    height: 800px;
    .vue-cropper {
      background-image: none;
      background-color: #000;
    }
  }
  .btns {
    padding: 0 20px;

    color: #fff;
    text-align: center;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 15px;
    img {
      width: 85px;
      height: 85px;
    }
    .cancel {
      background-color: #606465;
      padding: 15px 20px;
      width: 100px;
      border-radius: 10px;
    }
    .okey {
      background-color: #df6457;
      padding: 15px 20px;
      width: 100px;
      border-radius: 10px;
    }
  }
}
</style>

Summarize

This is the end of this article about the Vue image cropping component. For more relevant Vue image cropping component content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue project implements adding image cropping component
  • Detailed explanation of how to use vue-cropper, a Vue image cropping plugin
  • Vue realizes uploading after cropping pictures
  • Implementation of Vue image cropping and uploading component
  • Detailed explanation of implementing image cropping function in vue project
  • vue-image-crop is an example of a mobile image cropping component based on Vue
  • Vue-cropper The basic principles and ideas of picture cropping
  • Encapsulating Vue based on cropper.js to realize online image cropping component function
  • Cropper js implementation code of image cropping and uploading function based on Vue
  • Detailed explanation of the use of el-upload component and image cropping function component in ElementUI component of Vue project

<<:  Reasons and methods for Waiting for table metadata lock in MySQL

>>:  Example code and method of storing arrays in mysql

Recommend

Tutorial on using the frameset tag in HTML

Frameset pages are somewhat different from ordina...

Record the whole process of MySQL master-slave configuration based on Linux

mysql master-slave configuration 1. Preparation H...

Install mysql5.7.17 using RPM under Linux

The installation method of MySQL5.7 rpm under Lin...

18 killer JavaScript one-liners

Preface JavaScript continues to grow and prosper ...

MySQL 5.6 installation steps with pictures and text

MySQL is an open source small relational database...

In-depth understanding of JavaScript callback functions

Table of contents Preface Quick Review: JavaScrip...

Analysis and solution of abnormal problem of loading jar in tomcat

Description of the phenomenon: The project uses s...

Detailed explanation of how to view the number of MySQL server threads

This article uses an example to describe how to v...

Steps to deploy ingress-nginx on k8s

Table of contents Preface 1. Deployment and Confi...

How to dynamically add a volume to a running Docker container

Someone asked me before whether it is possible to...

Analysis of MySQL concurrency issues and solutions

Table of contents 1. Background 2. Slow query cau...

5 ways to migrate Docker containers to other servers

Migration is unavoidable in many cases. Hardware ...

Use js to call js functions in iframe pages

Recently, I have been working on thesis proposals ...