日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue-cropper插件實現圖片截取上傳組件封裝

瀏覽:28日期:2022-09-29 11:16:30

基于vue-cropper插件實現圖片截取上傳組件封裝的具體代碼,供大家參考,具體內容如下

需求場景:

后臺開發需要上傳圖片并進行相應比例尺寸圖片的截取,本組件開發采用Ant Design Vue組件庫搭配vue-cropper插件進行封裝

實現如下

vue-cropper插件實現圖片截取上傳組件封裝

vue-cropper插件實現圖片截取上傳組件封裝

html

<template> <div> <a-upload name='avatar' list-type='picture-card' :show-upload-list='false' :custom-request='customRequest' :before-upload='beforeUpload' : > <imgv-if='imageUrl && !loading':src='http://m.b3g6.com/bcjs/imageUrl'alt='avatar': /> <div v-else><a-icon :type='loading ? ’loading’ : ’plus’' /><div class='ant-upload-text'>上傳圖片</div> </div> </a-upload> <a-modal v-model='imageCut.isShowModal' @ok='finish' @cancel='imageCut.close' > <div v-if='imageCut.isShowModal'><div style='text-align:center'> <vueCropper ref='cropper' :img='imageCut.imgFile' :outputSize='outputSize' :outputType='outputType' :info='info' :full='full' :canMove='canMove' :canMoveBox='canMoveBox' :original='original' :autoCrop='autoCrop' :fixed='fixed' :fixedNumber='fixedNumber' :centerBox='centerBox' :infoTrue='infoTrue' :fixedBox='fixedBox' ></vueCropper></div> </div> </a-modal> </div></template>

js

<script>import { uploadImage } from ’@/api/common’import { VueCropper } from 'vue-cropper';export default { name: ’ImageUpload’, components: { VueCropper }, data() { return { loading: false, imageCut: {isShowModal: false,imgFile: ’’,init: imgFile => { this.imageCut.imgFile = imgFile this.imageCut.isShowModal = true},close: () => { this.imageCut.imgFile = ’’ this.imageCut.isShowModal = false} } } }, props: { imageUrl: String, width: { type: String, default: ’100px’ }, height: { type: String, default: ’100px’ }, canCut: { type: Boolean, default: false }, info: { type: Boolean, default: false }, // 裁剪框的大小信息 outputSize: { type: Number, default: 0.8 }, // 裁剪生成圖片的質量 outputType: { type: String, default: ’jpeg’ }, // 裁剪生成圖片的格式 canScale: { type: Boolean, default: true }, // 圖片是否允許滾輪縮放 autoCrop: { type: Boolean, default: true }, // 是否默認生成截圖框 // autoCropWidth: 300, // 默認生成截圖框寬度 // autoCropHeight: 200, // 默認生成截圖框高度 fixedBox: { type: Boolean, default: false }, // 固定截圖框大小 不允許改變 fixed: { type: Boolean, default: true }, // 是否開啟截圖框寬高固定比例 fixedNumber: { type: Array, default: () => [1, 1] }, // 截圖框的寬高比例 full: { type: Boolean, default: true }, // 是否輸出原圖比例的截圖 canMove: { type: Boolean, default: false }, canMoveBox: { type: Boolean, default: true }, // 截圖框能否拖動 original: { type: Boolean, default: false }, // 上傳圖片按照原始比例渲染 centerBox: { type: Boolean, default: true }, // 截圖框是否被限制在圖片里面 infoTrue: { type: Boolean, default: true } // true 為展示真實輸出圖片寬高 false 展示看到的截圖框寬高 }, methods: { beforeUpload(file) { const isJpgOrPng = file.type === ’image/jpeg’ || file.type === ’image/png’ if (!isJpgOrPng) {this.$message.error(’請上傳JPG或PNG文件!’) } const isLt2M = file.size / 1024 / 1024 < 2 if (!isLt2M) {this.$message.error(’請上傳2MB以下文件!’) } return isJpgOrPng && isLt2M }, customRequest(file) { if (this.canCut) {this.readFile(file.file) } else {this.loading = trueconst formData = new FormData()formData.append(’fileIdcard’, file.file)uploadImage(formData).then(res => { this.loading = false this.$emit(’uploadSuccess’, res.ossUrl)}) } }, readFile(file) { var reader = new FileReader() reader.readAsDataURL(file) reader.onload = () => {this.imageCut.init(reader.result) } }, finish() { this.$refs.cropper.getCropBlob(data => {this.loading = true// 上傳阿里云服務器const formData = new FormData()formData.append(’fileIdcard’, data)uploadImage(formData).then(res => { this.imageCut.close() this.loading = false this.$emit(’uploadSuccess’, res.ossUrl)}) }) } }}</script>

css

<style lang='less'>.avatar-uploader > .ant-upload { width: 100%; height: 100%;}.ant-upload-select-picture-card i { font-size: 32px; color: #999;}.ant-upload-select-picture-card .ant-upload-text { margin-top: 8px; color: #666;}.cropper-content { .cropper { width: auto; height: 400px; }}</style>

組件使用及說明

<image-upload:imageUrl='form.diagramUrl'@uploadSuccess='uploadSuccess' :can-edit='canCut':fixed-number='[16,9]' />

組件調用時需傳入canEdit屬性,指定組件是否啟動圖片選取后的裁剪功能,默認值為不啟用裁剪;需裁剪時可傳入fixedNumber屬性,定義裁剪框的寬高比

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品久久久久久久久妇女| 精品国产乱码久久久久久1区2匹| 岛国av在线网站| 卡一卡二国产精品| 欧美成人精品一级| 麻豆国产精品视频| 国产一区二区三区亚洲| 国产精品久久观看| 久久久精品久久久久久96| 亚洲午夜91| 好看的av在线不卡观看| 亚洲精华国产欧美| 天堂va蜜桃一区二区三区| 丝袜美腿成人在线| 在线一区视频| 亚洲一区二区日韩| 91大神在线观看线路一区| 国产精品一线天粉嫩av| 精品一区二区三区中文字幕在线| 欧美国产偷国产精品三区| 日本久久成人网| 欧美网站在线| 亚洲+小说+欧美+激情+另类| 国产精品久久久久毛片大屁完整版| 欧美日韩伊人| 久久精品免费看| 日韩精品首页| 中文国产一区| 日本一区福利在线| 国产欧美日韩在线观看视频| 精品一区二区三区中文字幕在线| 日本在线精品| 亚洲综合国产| 国产日韩欧美一区二区三区 | 国产综合激情| 亚洲一区二区三区久久久| 日本特黄久久久高潮| 国产精品啊v在线| 97精品一区| 亚洲一区区二区| 国产精品男女| 999久久久国产精品| 亚洲天堂日韩在线| 麻豆精品在线| 欧美成人亚洲| 国产亚洲第一伦理第一区| 日韩一区二区在线免费| 综合激情视频| 国产高潮在线| 亚洲日本国产| 天堂8中文在线最新版在线| 蜜乳av另类精品一区二区| 国产精品一区二区精品| 国产aa精品| 香蕉视频成人在线观看| 狂野欧美性猛交xxxx| 欧美aa一级| 人人精品久久| 国内精品99| 精品伊人久久| 美国三级日本三级久久99| 国产一区二区精品久| 首页欧美精品中文字幕| 日本一区二区免费高清| 综合亚洲自拍| 精精国产xxxx视频在线野外| 日韩国产高清在线| 久久久久久免费视频| 日本vs亚洲vs韩国一区三区二区| 亚洲综合在线电影| 国产日本精品| 国产视频一区三区| 日韩深夜视频| 国产欧美在线| 亚洲无线观看| 精品一区在线| 日韩综合在线| 国产欧美日韩在线一区二区| 乱人伦精品视频在线观看| 在线亚洲人成| 国产精品tv| 日韩在线观看中文字幕| 国产精品7m凸凹视频分类| 久久久91麻豆精品国产一区| 蜜臀久久99精品久久久久久9 | 日韩视频一区| 高清不卡亚洲| 国产精品.xx视频.xxtv| 在线亚洲观看| 久久久五月天| 福利一区二区三区视频在线观看| 日韩欧乱色一区二区三区在线| 美女网站一区| 久久久久久夜| 久久av日韩| 欧美一区成人| 视频一区二区国产| 91成人精品视频| 日韩不卡在线| 日韩电影二区| 久久久久久自在自线| 久久超级碰碰| 91九色综合| 亚洲精品自拍| 蜜臀精品一区二区三区在线观看| 精品1区2区3区4区| 国产99久久久国产精品成人免费| 中文字幕高清在线播放| 国内精品亚洲| 精品欧美日韩精品| 久久精品人人| 麻豆一区二区在线| 国产经典一区| 国产精品久久777777毛茸茸| 日韩av字幕| 日本va欧美va欧美va精品| 亚洲日本久久| 日韩精品久久久久久| 亚洲ab电影| 日韩精品免费视频人成 | 国产区精品区| 国产精品麻豆成人av电影艾秋| 欧美日韩中文| 国产精品欧美一区二区三区不卡| 天海翼亚洲一区二区三区| 亚洲三级视频| 日韩三区四区| 青青草视频一区| 国产欧美亚洲一区| 国产精品久久久久av蜜臀| 国产精品66| 国产精品久久观看| 欧美成人a交片免费看| 91精品一区二区三区综合在线爱| 欧美在线观看视频一区| 一区福利视频| 亚洲69av| 国产精品黄色片| 精品国产欧美日韩| 成人亚洲欧美| 欧美一区二区三区激情视频 | 国产女人18毛片水真多18精品| 欧美日本不卡高清| 国产精品777777在线播放| 国产成人免费精品| 四虎影视精品| 香蕉精品999视频一区二区| 在线精品福利| 国产欧美日韩在线观看视频| 精品久久久久中文字幕小说| 桃色av一区二区| 欧美日韩国产探花| 免费观看在线综合| 国产精品日韩精品在线播放| 亚洲永久av| 首页欧美精品中文字幕| 欧美日韩夜夜| 91免费精品| 最新国产拍偷乱拍精品| 午夜久久av| 精品国产亚洲一区二区三区大结局 | 欧美影院三区| 蜜臀av一区二区在线免费观看| 日韩精品1区2区3区| 久久免费影院| 欧美精品一区二区久久| 亚洲a级精品| 一区二区精品伦理...| 欧美日韩国产亚洲一区| 久久精品999| 亚洲va中文在线播放免费| 久久一二三区| 久久只有精品| 黄色成人91| 美女视频免费精品| 夜夜嗨一区二区| 国产精品v一区二区三区| 激情欧美一区| 日本电影久久久| 国产欧美一区二区三区精品酒店| 免费日韩视频| 高清在线一区| 综合日韩在线| 日韩欧美国产精品综合嫩v| 视频一区在线视频| 国产在线观看91一区二区三区| 国产一区成人| 精品高清久久| 视频一区在线播放| a天堂资源在线| 午夜视频一区二区在线观看| 日韩欧美一区二区三区在线视频| 日韩中文av| 国产亚洲一区二区手机在线观看 | 亚洲韩日在线| 国产欧美日本| 快she精品国产999| 日韩88av| 91精品国产一区二区在线观看| 久久精品国产www456c0m|