• vue项目 (element-ui + vue-cropper) 创建一个实用的图片尺寸调整 角度调整 图片上传工具


    还是先在项目中引入依赖

    npm install element-ui@2 --save
    
    • 1
    npm install element-plus --save
    
    • 1
    npm install vue-cropper@next --save
    
    • 1

    main.js 参考代码如下

    import {createApp} from 'vue'
    import App from './App.vue'
    
    import ElementPlus from 'element-plus';
    import 'element-plus/dist/index.css';
    
    createApp(App).use(ElementPlus).mount('#app')
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    这样我们element-ui组件库就进来了
    因为我们这个是新建的项目 代码就直接写在App.vue里了
    App.vue参考代码如下

    <template>
      <div id = "app">
          <VueCropper
            ref="cropper"
            :img="options.img"
            style = "width: 400px;height: 300px;"
            :info="true"
            :autoCrop="options.autoCrop"
            :autoCropWidth="options.autoCropWidth"
            :autoCropHeight="options.autoCropHeight"
            :fixedBox="options.fixedBox"
            @realTime="realTime"
          ></VueCropper>
          <div class = "control">
              <el-upload action="#" :show-file-list="false" :before-upload="beforeUpload">
                  <el-button size="small">
                      选择
                  <i class="el-icon-upload el-icon--right"></i>
                  </el-button>
              </el-upload>
              <div>
                  <el-button size="small" @click="changeScale(1)">放大</el-button>
              </div>
              <div>
                  <el-button size="small" @click="changeScale(-1)">缩小</el-button>
              </div>
              <div>
                  <el-button size="small" @click="rotateLeft()">左侧偏转</el-button>
              </div>
              <div>
                  <el-button size="small" @click="rotateRight()">右侧偏转</el-button>
              </div>
          </div>
          <div class = "control">
              <el-button type="primary"  @click="Submit()">提交</el-button>
          </div>
      </div>
    </template>
    
    <script>
    import 'vue-cropper/dist/index.css'
    
    //组件中使用
    import { VueCropper }  from "vue-cropper";
    export default {
      name: 'App',
      components: { VueCropper },
      data(){
        return {
          options: {
              img: '', //裁剪图片的地址
              autoCrop: true, // 是否默认生成截图框
              autoCropWidth: 200, // 默认生成截图框宽度
              autoCropHeight: 200, // 默认生成截图框高度
              fixedBox: true // 固定截图框大小 不允许改变
          },
        }
      },
      methods:{
          realTime(data) {
              console.log(data);
          },
           // 上传预处理
          beforeUpload(file) {
              if (file.type.indexOf("image/") == -1) {
                  this.$modal.msgError("文件格式错误,请上传图片类型,如:JPG,PNG后缀的文件。");
              } else {
                  const reader = new FileReader();
                  reader.readAsDataURL(file);
                  reader.onload = () => {
                  this.options.img = reader.result;
                  };
              }
          },
          // 图片缩放
          changeScale(num) {
              num = num || 1;
              this.$refs.cropper.changeScale(num);
          },
          // 向左旋转
            rotateLeft() {
                this.$refs.cropper.rotateLeft();
            },
            // 向右旋转
            rotateRight() {
                this.$refs.cropper.rotateRight();
            },
            Submit(){
                this.$refs.cropper.getCropData(data => {
                  console.log(data);
                })
            }
      }
    }
    </script>
    
    <style>
    .control{
        display: flex;
        margin-top:15px;
    }
    </style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103

    然后我们得到的界面效果就是这样的
    在这里插入图片描述
    点击选择 选择一张图片上传上去
    在这里插入图片描述
    在这里插入图片描述
    放大缩小 都可以玩一玩
    还有偏转
    在这里插入图片描述
    点击提交时这里我们只是在控制台输出了一下处理好的图片加密字符串
    上传图片需要后台人员配合处理
    在这里插入图片描述

  • 相关阅读:
    巧妙实现防止按钮重复点击
    从零开始学习CAN总线协议(一)
    HK32MCU应用笔记| HK32F103x/C/D/E-TIM1的应用及注意事项
    TensorFlow在推荐系统中的分布式训练优化实践
    高并发系统架构设计之实战篇:计数系统之计数器设计
    基于XML方式的Bean的配置概述
    MySQL修改时间添加时间自动更新
    【王道】计算机组成原理第三章存储系统(三)
    HDLBits: 在线学习 SystemVerilog(九)-Problem 36-42
    计算机保研,maybe this is all you need(普通双非学子上岸浙大工程师数据科学项目)
  • 原文地址:https://blog.csdn.net/weixin_45966674/article/details/125452183