<template> <div> <div class="cropper-content"> <div class="cropper"> <vueCropper ref="cropper" :img="option.img" :outputSize="option.size" :outputType="option.outputType" :info="true" :full="option.full" :canMove="option.canMove" :canMoveBox="option.canMoveBox" :original="option.original" :autoCrop="option.autoCrop" :autoCropWidth="option.autoCropWidth" :autoCropHeight="option.autoCropHeight" :fixedBox="option.fixedBox" @realTime="realTime" @imgLoad="imgLoad"></vueCropper> </div> <div class="show-preview" :style="{'width': previews.w + 'px', 'height': previews.h + 'px', 'overflow': 'hidden', 'margin': '5px'}"> <div :style="previews.div" class="preview"> <img :src="previews.url" :style="previews.img"> </div> </div> </div> <div class="footer-btn"> <div class="scope-btn"> <label class="btn" for="uploads">選擇圖片</label> <input type="file" id="uploads" style="position:absolute; clip:rect(0 0 0 0);" accept="image/png, image/jpeg, image/gif, image/jpg" @change="uploadImg($event, 1)"> <Button type="ghost" @click="changeScale(1)" icon="plus-round"></Button> <Button type="ghost" @click="changeScale(-1)" icon="minus-round"></Button> <Button type="ghost" @click="rotateLeft"><span style="font-weight: 600;">↺</span></Button> <Button type="ghost" @click="rotateRight"><span style="font-weight: 600;">↻</span></Button> </div> <div class="upload-btn"> <Button type="primary" style="margin-left: 46px;" @click="down('base64')">上傳頭像</Button> </div> </div> </div> </template>
<script> import VueCropper from 'vue-cropper' export default { data() { return { crap: false, previews: {}, option: { img: 'http:img1.vued.vanthink.cn/vued751d13a9cb5376b89cb6719e86f591f3.png', size: 1, full: false, // 輸出原圖比例截圖 props名full outputType: 'png', canMove: true, original: false, canMoveBox: true, autoCrop: true, autoCropWidth: 200, autoCropHeight: 200, fixedBox: true }, downImg: '#' } }, components: { VueCropper }, methods: { changeScale(num) { num = num || 1 this.$refs.cropper.changeScale(num) }, rotateLeft() { this.$refs.cropper.rotateLeft() }, rotateRight() { this.$refs.cropper.rotateRight() }, finish(type) { // 輸出 // var test = window.open('about:blank') // test.document.body.innerHTML = '圖片生成中..' if (type === 'blob') { this.$refs.cropper.getCropBlob(data => { var img = window.URL.createObjectURL(data) this.model = true this.modelSrc = img }) } else { this.$refs.cropper.getCropData(data => { this.model = true this.modelSrc = data }) } }, // 實時預覽函數 realTime(data) { this.previews = data }, down(type) { // event.preventDefault() var aLink = document.createElement('a') aLink.download = 'author-img' // 輸出 if (type === 'blob') { this.$refs.cropper.getCropBlob(data => { console.log(data) this.downImg = window.URL.createObjectURL(data) // aLink.download = this.downImg; console.log(this.downImg) aLink.href = window.URL.createObjectURL(data) aLink.click() }) } else { this.$refs.cropper.getCropData(data => { this.downImg = data // aLink.href = data // aLink.click() // 將頭像圖片數據發送給後臺 }) } }, uploadImg(e, num) { //上傳圖片 // this.option.img var file = e.target.files[0] if (!/\.(gif|jpg|jpeg|png|bmp|GIF|JPG|PNG)$/.test(e.target.value)) { alert('圖片類型必須是.gif,jpeg,jpg,png,bmp中的一種') return false } var reader = new FileReader() reader.onload = e => { let data if (typeof e.target.result === 'object') { // 把Array Buffer轉化爲blob 若是是base64不須要 data = window.URL.createObjectURL(new Blob([e.target.result])) } else { data = e.target.result } if (num === 1) { this.option.img = data } else if (num === 2) { this.example2.img = data } } // 轉化爲base64 reader.readAsDataURL(file) // 轉化爲blob // reader.readAsArrayBuffer(file) }, imgLoad(msg) { console.log(msg) } } } </script>
<style lang="less"> .cropper-content { display: flex; display: -webkit-flex; justify-content: flex-end; -webkit-justify-content: flex-end; .cropper { width: 350px; height: 300px; } .show-preview { flex: 1; -webkit-flex: 1; display: flex; display: -webkit-flex; justify-content: center; -webkit-justify-content: center; .preview { overflow: hidden; border-radius: 50%; border: 1px solid #cccccc; background: #cccccc; margin-left: 40px; } } } .footer-btn { margin-top: 30px; display: flex; display: -webkit-flex; justify-content: flex-end; -webkit-justify-content: flex-end; .scope-btn { width: 350px; display: flex; display: -webkit-flex; justify-content: space-between; -webkit-justify-content: space-between; } .upload-btn { flex: 1; -webkit-flex: 1; display: flex; display: -webkit-flex; justify-content: center; -webkit-justify-content: center; } .btn { outline: none; display: inline-block; line-height: 1; white-space: nowrap; cursor: pointer; -webkit-appearance: none; text-align: center; -webkit-box-sizing: border-box; box-sizing: border-box; outline: 0; margin: 0; -webkit-transition: 0.1s; transition: 0.1s; font-weight: 500; padding: 10px 15px; font-size: 12px; border-radius: 3px; color: #fff; background-color: #67c23a; border-color: #67c23a; } } </style>
vue-cropper的GitHub項目地址:https://github.com/xyxiao001/vue-cropper。有興趣的能夠更深刻的研究其餘功能,這裏只作參考用,最終效果以下vue
注意:當前功能是在使用了iview的基礎上實現的效果,若是不是在iview下實現的項目,注意修改下組件中buttton的實現方式git