首页 > Web开发 > 详细

Vue实现前端裁剪(elementUI上传+vueCropper实现)

时间:2021-06-18 19:05:17      阅读:23      评论:0      收藏:0      [点我收藏+]

data中需要定义的变量

            logoUrl: ‘‘, // 裁剪后的图片
            // 裁剪组件是否展示
            dialogVisible: false,
            // 裁剪组件的基础配置option
            option: {
                img: ‘‘, // 裁剪图片的地址
                info: true, // 裁剪框的大小信息
                outputSize: 0.8, // 裁剪生成图片的质量
                outputType: ‘png‘, // 裁剪生成图片的格式
                canScale: false, // 图片是否允许滚轮缩放
                autoCrop: true, // 是否默认生成截图框
                autoCropWidth: 180, // 默认生成截图框宽度
                autoCropHeight: 64, // 默认生成截图框高度
                fixedBox: true, // 固定截图框大小 不允许改变
                fixed: true, // 是否开启截图框宽高固定比例
                fixedNumber: [180, 64], // 截图框的宽高比例
                full: true, // 是否输出原图比例的截图
                canMoveBox: false, // 截图框能否拖动
                original: false, // 上传图片按照原始比例渲染
                centerBox: false, // 截图框是否被限制在图片里面
                infoTrue: true // true 为展示真实输出图片宽高 false 展示看到的截图框宽高
            },     

 

 

首先放一个上传图片的图标,用elementUI组件的upload

<el-upload
    class="avatarUploader"
    :auto-upload="false"
    action=""
    :show-file-list="false"
    :on-change=‘changeUpload‘>
    <img v-if="logoUrl" :src="logoUrl" class="avatar">
    <i v-else class="el-icon-plus"></i>
</el-upload>

注意:auto-upload一定要设置成false, logoUrl代表裁剪后展示的图片,本例只可上传一张图片,如需多张自己调整

 

使用npm 安装 VueCropper,并在页面的js部分引入

import Vue from ‘vue‘
import VueCropper from ‘vue-cropper‘
// 裁剪图片
Vue.use(VueCropper)

html部分

 <!-- vueCropper 剪裁图片实现-->
        <el-dialog title="图片剪裁" :visible.sync="dialogVisible" append-to-body>
            <div class="cropper-content">
                <div class="cropper" style="text-align:center">
                    <vueCropper
                        ref="cropper"
                        :img="option.img"
                        :outputSize="option.outputSize"
                        :outputType="option.outputType"
                        :info="true"    
                        :full="option.full"
                        :autoCropHeight="option.autoCropHeight"
                        :autoCropWidth="option.autoCropWidth"
                        :canMove="option.canMove"
                        :canMoveBox="option.canMoveBox"
                        :original="option.original"
                        :autoCrop="option.autoCrop"
                        :fixed="option.fixed"
                        :fixedNumber="option.fixedNumber"
                        :centerBox="option.centerBox"
                        :infoTrue="option.infoTrue"
                        :fixedBox="option.fixedBox"
                    ></vueCropper>
                </div>
            </div>
            <div slot="footer" class="dialog-footer">
                <div class="rowJe">
                    <div @click="dialogVisible = false" class="cancelBtn">取 消</div>
                    <div type="primary" @click="finish" :loading="loading" class="ensureBtn">确认</div>
                </div>
                
            </div>
        </el-dialog>

使用el-upload 上传图片后弹出裁剪页面

// 上传按钮   限制图片大小
        changeUpload(file, fileList) {
            const isLt2M = file.size / 1024 / 1024 < 2
            if (!isLt2M) {
                alert(‘上传图片不能超过2M‘)
                return false
            }
            this.cutImgFile = file.raw
            this.fileinfo = file
            // console.log("file",file,fileList)

            // 上传成功后将图片地址赋值给裁剪框显示图片
            this.$nextTick(() => {
                this.option.img = URL.createObjectURL(file.raw)
                this.dialogVisible = true
                // console.log("图片地址:",this.option.img)
            })
        },

裁剪完成触发的方法

// 点击裁剪,这一步是可以拿到处理后的地址
        finish() {
            this.$refs.cropper.getCropBlob((data) => {
                // data 是裁剪后的文件数据,需转成后端需要的格式请求上传接口
                const file = new window.File([data],this.cutImgFile.name)
                var formData = new FormData();
                formData.append("file", file);
                // uplodeImgInstitution 封装的后端接口,
                uplodeImgInstitution(formData).then((res) => {
                    if (res.resultCode == 200) {
                        console.log("图片上传成功:",res)
                        this.logoUrl = res.data
                        this.dialogVisible = false
                        this.editInfo()
                    } else {
                        alert(‘上传图片失败‘)
                    }
                });
            })
        }

 

Vue实现前端裁剪(elementUI上传+vueCropper实现)

原文:https://www.cnblogs.com/pyx-blog/p/14899506.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!