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

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

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

瀏覽:25日期: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://www.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久久,三上悠亚国产精品一区二区三区
国产免费久久| av日韩中文| 国产成人久久精品麻豆二区 | 石原莉奈一区二区三区在线观看 | 狠狠久久伊人中文字幕| 精品日韩在线| bbw在线视频| 中文字幕高清在线播放| 日韩啪啪电影网| 日本精品另类| 国产视频一区二区在线播放| 国产精品香蕉| 国产一区调教| 久久精品青草| 国产精品亲子伦av一区二区三区| 欧美aa在线视频| av资源中文在线| 欧美日韩国产一区二区三区不卡| 亚洲激情精品| 蜜桃久久久久久久| 欧美日本不卡| 日本激情一区| 国产一区日韩欧美| 日韩一区欧美二区| 91综合久久爱com| 国语精品一区| 婷婷六月综合| 日韩欧美另类中文字幕| 美女国产一区二区三区| 欧洲亚洲一区二区三区| 国产亚洲精品v| 欧美一区自拍| 欧美aa一级| 蜜臀91精品一区二区三区| 日韩av影院| 青青青免费在线视频| 宅男噜噜噜66国产日韩在线观看| 日韩一区二区三区精品| 精品日本视频| av不卡在线看| 久久国产精品色av免费看| 高清不卡亚洲| 蜜臀va亚洲va欧美va天堂| 美女国产精品久久久| 亚洲国产不卡| 国产毛片精品| 91精品国产乱码久久久久久久| 一区二区三区午夜视频| 激情综合婷婷| 夜久久久久久| 国产精品1luya在线播放| 99免费精品| 日韩福利视频导航| 亚洲人成在线网站| 亚洲综合福利| 日韩精品永久网址| 亚洲字幕久久| 波多野结衣久久精品| 亚洲精品欧美| 中文字幕系列一区| 国产精品亚洲欧美一级在线| 午夜久久福利| 美女精品视频在线| 亚洲一区二区免费在线观看| 老牛国内精品亚洲成av人片| 在线亚洲欧美| 人在线成免费视频| 日韩有码av| 久久久久久免费视频| 国产精品久久久久久模特| 亚洲美洲欧洲综合国产一区| 久久久久亚洲精品中文字幕| 亚洲精品无播放器在线播放| 999久久久91| 美女视频黄久久| 亚洲男人在线| 欧美精选一区二区三区| 久久这里只有精品一区二区| 视频在线观看一区二区三区| 成人污污视频| 日韩1区2区日韩1区2区| 精品日韩毛片| 日韩在线短视频| 国产精品mv在线观看| 亚洲字幕久久| 亚洲综合欧美| 精品欧美久久| 久久婷婷亚洲| 91精品视频一区二区| 免费精品视频| 亚洲一级特黄| 亚洲啊v在线| 久久精品网址| 国产精品国码视频| 日本一区免费网站| 国产精品女主播一区二区三区| 亚洲人成在线网站| 国内精品亚洲| 久久99久久人婷婷精品综合| 一区二区国产在线| 国产视频一区三区| 亚洲精品va| 91精品福利| 欧美性感美女一区二区| 91嫩草亚洲精品| 麻豆国产91在线播放| 欧美一区自拍| 91精品视频一区二区| 日韩美女国产精品| 日韩在线观看一区二区| 欧美~级网站不卡| 精品三级久久| 欧美成a人免费观看久久| 日韩av专区| 成人日韩av| 成午夜精品一区二区三区软件| 国产精品对白| 国产日韩在线观看视频| 日韩美女精品| 日本少妇精品亚洲第一区| 日韩有吗在线观看| 色狠狠一区二区三区| 亚洲精品视频一二三区| 亚洲精品成人一区| 亚洲理论在线| 亚洲香蕉久久| 日韩精品高清不卡| 国产日产一区| 国产精品久久久久久久久久白浆| 国产欧美啪啪| 韩国女主播一区二区三区| 91亚洲自偷观看高清| 蜜臀国产一区| 在线精品视频在线观看高清| 国产农村妇女精品一二区| 蜜桃久久av| 日本特黄久久久高潮| 免费一区二区三区在线视频| sm久久捆绑调教精品一区| 日韩免费一区| 久久亚洲在线| 亚洲欧美日韩精品一区二区| 亚洲精品一区二区在线播放∴| 久久国产欧美日韩精品| 福利欧美精品在线| 国内精品福利| 亚洲一二av| 久久成人福利| 日韩伦理一区| 国产一区白浆| 欧美午夜三级| 国产成人精品亚洲线观看| 久久精品青草| 亚州av一区| 久久久久九九精品影院| 中文字幕人成乱码在线观看| 欧美 日韩 国产精品免费观看| 一区二区国产精品| 国产精品porn| 国产91精品对白在线播放| 首页国产欧美久久| 免费在线成人| 黄色成人精品网站| 日本成人中文字幕| 国产精品1区| 婷婷亚洲综合| 国产一卡不卡| 日韩电影免费网址| 亚洲色图综合| 精品国产一区二区三区av片| 99久久亚洲精品蜜臀| 日韩一区二区三区免费视频| 精品久久97| 红桃视频国产精品| 国产精品99久久久久久董美香| 国产一区清纯| 国产精品一二| 国户精品久久久久久久久久久不卡| 香蕉久久久久久| 国产精品久久久久久久免费观看 | 成人高清一区| 视频一区视频二区在线观看| 国产欧美日韩亚洲一区二区三区| 日本免费一区二区三区四区| 亚洲网址在线观看| 日韩av在线中文字幕| 亚洲免费毛片| 日本综合字幕| 国产女人18毛片水真多18精品| 亚洲伦乱视频| 欧美在线日韩| 婷婷色综合网| 精品亚洲自拍| 日本不卡高清| 国产一区清纯| 国产videos久久| 日韩高清不卡在线| 女人av一区| 美女久久99| 亚洲精品九九|