电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

vue 圖片裁剪上傳組件的實(shí)現(xiàn)

瀏覽:57日期:2022-10-31 17:38:26

先看一下總體效果:

上傳文件做了大小和類型的限制,在動圖中無法展現(xiàn)出來。

vue 圖片裁剪上傳組件的實(shí)現(xiàn)

使用file類型的input實(shí)現(xiàn)選擇本地文件

但是瀏覽器原生的文件上傳按鈕的顏值不盡人意,而且按鈕上的文字是無法改變的,我需要把這個(gè)上傳文件的按鈕改造一下。

方法1:使用label元素來觸發(fā)一個(gè)隱藏的file類型的 input元素;(缺點(diǎn):在多人開發(fā)時(shí),可能出現(xiàn)重復(fù)的元素id,導(dǎo)致難以預(yù)料的bug)

<input type='file' id=’up_file_input’ v-show=’false’ ><label for=’up_file_input’></label> 方法2:或者在這個(gè)label元素的click事件函數(shù)中手動觸發(fā)文件上傳按鈕的click事件。

<input type='file' v-show=’false’ ref='inputFileUp' ><label @click=’$refs.inputFileUp.click()’></label>

使用input的change事件獲取選擇的本地圖片并進(jìn)行校驗(yàn)

上傳圖片的校驗(yàn)規(guī)則及提示語由父組件通過 prop 傳遞給子組件,格式如下:

const img_valit = { type: /^.*.(jpg|png|jpeg)$/i, // 文件格式校驗(yàn) type_error_msg: ’上傳頭像圖片只能是 jpg 或者 png 格式!’, size: 3, // 文件大小校驗(yàn) size_error_msg: ’上傳的圖片大小不能超過3MB’}

這里需要注意: 需要在上傳文件按鈕的click事件中手動清空這個(gè)文件類型輸入框的值,解決選擇和上次相同的文件之后無法觸發(fā) change事件的問題

function fileInputClick(event) { event.target.value = '';}function coverImgChange(event) { const file = event.target.files[0]; // 在組件的自定義屬性中定義一個(gè)變量 originalFile 來保存當(dāng)前上傳的文件 this.$options._myOpt.originalFile = file; // 獲取對文件的校驗(yàn)規(guī)則 const { type, size, type_error_msg, size_error_msg } = this.img_valit; // 校驗(yàn)文件類型和文件大小 const isJPG_PNG = type.test(file.name), isLt5M = file.size / 1024 / 1024 <= size; !isLt5M && this.$message.error(size_error_msg); !isJPG_PNG && this.$message.error(type_error_msg); // 文件通過校驗(yàn),打開裁剪彈窗 if (isJPG_PNG && isLt5M) { this.cropImgUrl = window.URL.createObjectURL(file); this.dialogVisible = true; } }

打開彈窗進(jìn)行圖片裁剪

彈窗使用的 Element-UI 中的彈窗, 圖片裁剪是第三方插件 vue-cropper。圖片裁剪插件中的一些配置可以參考插件官方文檔,下面的代碼中省略了配置部分的代碼。

<el-dialog :visible.sync='dialogVisible' width=’800px’> <div class='dialog-content'> <div class='cropper-image'> <vue-cropper ref='cropper' :img='cropImgUrl' @realTime='realTime' ></vue-cropper> </div> <!-- 圖片裁剪之后的預(yù)覽 --> <div class='preview-wrapper'> <div : > <div :style='previews.div'> <img :src='http://www.hdgsjgj.cn/bcjs/previews.url' :style='[previews.img]'> </div> </div> <p class='preview-text'>裁剪結(jié)果預(yù)覽</p> </div> </div> <div slot='footer' class='dialog-footer'> <button @click='dialogEsc()'>取 消</button> <button @click='dialogSure()'>確 定</button> </div> </el-dialog>

向服務(wù)器發(fā)送請求上傳圖片

上傳文件接口中,向后臺發(fā)送請求的參數(shù)為 {image: 文件本身(File類型), filename: 文件名}

function realTime(data) { this.previews = data;}// 裁剪彈窗中確定按鈕的點(diǎn)擊事件function dialogSure() { const ajaxConfig = { headers: { 'Content-Type': 'multipart/form-data' } }; // 上傳圖片的文件名 let cropFileName = this.$options._myOpt.originalFile.name.match(/([^/]+)(?=.)/gi)[0] || Date.now().toString(); this.$refs.cropper.getCropBlob(blob => { // IE 和 Edge 不支持 File 構(gòu)造函數(shù) let cropFile = new File( [blob], cropFileName.toString() + '.' + (this.cropperConfig.outputType || 'jpg'), { type: blob.type } ); let upParams = new FormData(); upParams.append('image', cropFile); upParams.append('filename', cropFile.fileName); axios.post(this.up_action, upParams).then(({ data }) => { if (data.status === 0) { this.coverUlr = window.URL.createObjectURL(blob); this.pathToParent({ fileId: data.result.fileId, fileExt: data.result.fileExt }); } else { this.coverUlr = ''; this.pathToParent({ fileId: '', fileExt: '' }); } }); }); this.dialogVisible = false; } // 向父組件傳遞上傳文件成功之后后臺返回的數(shù)據(jù) function pathToParent(filePath) { this.$emit('getFilePath', filePath); }

以上就是vue 圖片裁剪上傳組件的實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于vue 圖片裁剪上傳組件的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: CE认证_产品欧盟ROHS-REACH检测机构-商通检测 | 制氮设备_PSA制氮机_激光切割制氮机_氮气机生产厂家-苏州西斯气体设备有限公司 | 电加热导热油炉-空气加热器-导热油加热器-翅片电加热管-科安达机械 | 沉降天平_沉降粒度仪_液体比重仪-上海方瑞仪器有限公司 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 | 巨野月嫂-家政公司-巨野县红墙安康母婴护理中心 | 耐酸碱胶管_耐腐蚀软管总成_化学品输送软管_漯河利通液压科技耐油耐磨喷砂软管|耐腐蚀化学软管 | 常州减速机_减速机厂家_常州市减速机厂有限公司 | RS系列电阻器,RK_RJ启动调整电阻器,RQ_RZ电阻器-上海永上电器有限公司 | 耐酸泵,耐腐蚀真空泵,耐酸真空泵-淄博华舜耐腐蚀真空泵有限公司 精密模具-双色注塑模具加工-深圳铭洋宇通 | 盛源真空泵|空压机-浙江盛源空压机制造有限公司-【盛源官网】 | 共享雨伞_共享童车_共享轮椅_共享陪护床-共享产品的领先者_有伞科技 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 电杆荷载挠度测试仪-电杆荷载位移-管桩测试仪-北京绿野创能机电设备有限公司 | 破碎机_上海破碎机_破碎机设备_破碎机厂家-上海山卓重工机械有限公司 | 99文库_实习生实用的范文资料文库站 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 山东柳店新能源科技有限公司| C形臂_动态平板DR_动态平板胃肠机生产厂家制造商-普爱医疗 | 黑龙江京科脑康医院-哈尔滨精神病医院哪家好_哈尔滨精神科医院排名_黑龙江精神心理病专科医院 | 砍排机-锯骨机-冻肉切丁机-熟肉切片机-预制菜生产线一站式服务厂商 - 广州市祥九瑞盈机械设备有限公司 | 济南网站建设|济南建网站|济南网站建设公司【济南腾飞网络】【荐】 | 企业微信scrm管理系统_客户关系管理平台_私域流量运营工具_CRM、ERP、OA软件-腾辉网络 | 家德利门业,家居安全门,别墅大门 - 安徽家德利门业有限公司 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 航空铝型材,7系铝型材挤压,硬质阳*氧化-余润铝制品 | 河南档案架,档案密集架,手动密集架,河南密集架批发/报价 | 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 空调风机,低噪声离心式通风机,不锈钢防爆风机,前倾皮带传动风机,后倾空调风机-山东捷风风机有限公司 | 橡胶接头_橡胶软接头_可曲挠橡胶接头-巩义市创伟机械制造有限公司 | 细沙回收机-尾矿干排脱水筛设备-泥石分离机-建筑垃圾分拣机厂家-青州冠诚重工机械有限公司 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 焦作网 WWW.JZRB.COM| 铣刨料沥青破碎机-沥青再生料设备-RAP热再生混合料破碎筛分设备 -江苏锡宝重工 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 对夹式止回阀_对夹式蝶形止回阀_对夹式软密封止回阀_超薄型止回阀_不锈钢底阀-温州上炬阀门科技有限公司 | 上海冠顶工业设备有限公司-隧道炉,烘箱,UV固化机,涂装设备,高温炉,工业机器人生产厂家 | 防爆暖风机_防爆电暖器_防爆电暖风机_防爆电热油汀_南阳市中通智能科技集团有限公司 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | 彩超机-黑白B超机-便携兽用B超机-多普勒彩超机价格「大为彩超」厂家 |