欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

通過vue-cropper選取本地圖片自定義裁切圖片比例

 更新時間:2023年07月21日 11:33:47   作者:海的天空1661  
這篇文章主要介紹了Vue選取本地圖片,自定義裁切圖片比例?vue-cropper,本文分步驟結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

裁切圖片,按照比例裁切,分步驟

1:el-upload選擇本地圖片(分選擇本地和上傳兩步驟)

2:在on-change回調(diào)方法中拿到el-upload選中的圖片,顯示在vueCropper上()。

2.1:在vueCropper顯示前,用el-dialog彈框顯示。

3:提交:拿到vueCropper的回調(diào)方法realTime中的裁切好的圖片,轉(zhuǎn)化為base64,再轉(zhuǎn)為file文件提交上傳給服務(wù)器。

看代碼步驟

一:el-upload

el-upload連接:Upload | Element Plus 

簡單介紹,這個是一個選擇本地圖片上傳的功能,這“選擇本地圖片”“上傳服務(wù)器”兩個功能可以一起實(shí)現(xiàn),也可以分開實(shí)現(xiàn),因我這里需要,是分開實(shí)現(xiàn)。

這里選擇的是elementplus的選取上傳功能組件,當(dāng)然也可以自己去寫。

 <el-upload 
    accept="image/jpeg, image/gif, image/png, image/jpg" 
    ref='upload'           
    :action="uploadAction"          //上傳方法,
    :auto-upload="false"            //是否自動上傳文件。這里需要false
    :headers="uploadHeaders"     
    :limit="1" 
    :show-file-list="false"         //上傳顯示的列表
    :on-change="onChange"           //選擇文件或上傳文件成功或上傳文件失敗時的鉤子功能
    >
    <el-button type="default">選擇圖片</el-button>
 </el-upload>
// 選擇本地圖片
        onChange(file, fileList) {
            this.$nextTick(() => {
                this.option.img = URL.createObjectURL(file.raw);
                this.$refs.upload.clearFiles();
                this.dialogVisibleImgs = true; // 控制顯示彈框
            })
        },

二:拿到圖片,彈框顯示(這里分步驟)

從el-upload的onchange方法中拿到img。讓el-dialog彈框顯示vuecropper。并上傳

<el-dialog class="cropperDialog" 
        :close-on-click-modal="false" 
        title="圖片裁剪" 
        :visible.sync="dialogVisibleImgs"
        width="40%" 
        @close="close"
        >
            <div class="cropper-content" v-if="option.img">
                <div class="cropper" style="text-align: center;">
                    <vueCropper     
                        ref="cropper" 
                        :img="option.img" 
                        :output-size="option.size" 
                        :output-type="option.outputType"
                        :info="true" 
                        :full="option.full" 
                        :fixed="option.fixed" 
                        :fixed-number="option.fixedNumber"
                        :can-move="option.canMove" 
                        :can-move-box="option.canMoveBox" 
                        :fixed-box="option.fixedBox"
                        :original="option.original"      //上傳圖片按照原始比例渲染 原圖裁切大小的需寫這個
                        :auto-crop="option.autoCrop" 
                        :auto-crop-width="option.autoCropWidth"  // 默認(rèn)生成裁圖框?qū)挾?原圖裁切大小的需寫這個" 
                        :auto-crop-height="option.autoCropHeight"  //     默認(rèn)生成裁圖框高度 原圖裁切大小的需寫這個
                        :center-box="option.centerBox" 
                        :high="option.high"
                        model="cover" 
                        :max-img-size="option.max" 
                        :info-true="option.infoTrue" 
                        @realTime="realTime"    //實(shí)時預(yù)覽函數(shù)
                        >
                    </vueCropper>
                </div>
            </div>
            <div class="dialogbottom" style="display: flex; align-items: center; justify-content: space-between;">
                <div class="preview">
                    <!-- 這里傳入封裝的裁切比例 -->
                    <div class="title">封面預(yù)覽 圖片比例({{ fixedNum[0] }}:{{fixedNum[1]}})</div>
                    <div class="preview_clumk">
                        <img :src="previewImageHeight" alt="" style="width:90px;"
                            object-fit="contain">
                    </div>
                </div>
                <div>
                    <el-button style="margin-left: 10px; margin-top: 20px; " type="success" :loading="loading"
                        @click="uploadEnd">上傳并保存</el-button>
                </div>
            </div>
        </el-dialog>
// // 實(shí)時預(yù)覽函數(shù)
        realTime(data) {
            // ①獲取截圖的 base64 數(shù)據(jù)
            this.$refs.cropper.getCropData((data) => {
                this.previewImageHeight = data;
            })
        },
        //將base64轉(zhuǎn)換為file文件流
        base64toFile(dataurl, filename = 'file') {
            let arr = dataurl.split(',')
            let mime = arr[0].match(/:(.*?);/)[1]
            let suffix = mime.split('/')[1]
            let bstr = atob(arr[1])
            let n = bstr.length
            let u8arr = new Uint8Array(n)
            while (n--) {
                u8arr[n] = bstr.charCodeAt(n)
            }
            return new File([u8arr], `${filename}.${suffix}`, {
                type: mime,
            })
        },
        // 自定義上傳給后臺,這里能最大限度自定義
        uploadEnd() {
            if (!this.option.img && this.option.img == '')
                return this.ME('請先選擇圖片')
            this.loading = true;
            if (this.previewImageHeight !== '') {
                const optionImg = this.base64toFile(this.previewImageHeight);
                const formData = new FormData()
                formData.append('file', optionImg);
                this.$api.Media.Image.Upload(formData).then((res) => {
                    this.loading = false;
                    this.imageUrl = res.data.url;
                    this.$message.success('上傳成功');
                    this.$emit("input", this.imageUrl);
                    this.close();
                }).catch(() => {
                    this.loading = false;
                })
            }
        }

到此這篇關(guān)于Vue選取本地圖片,自定義裁切圖片比例 vue-cropper的文章就介紹到這了,更多相關(guān)vue自定義裁切圖片比例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 完美解決通過IP地址訪問VUE項(xiàng)目的問題

    完美解決通過IP地址訪問VUE項(xiàng)目的問題

    這篇文章主要介紹了完美解決通過IP地址訪問VUE項(xiàng)目的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue組件jsx語法的具體使用

    vue組件jsx語法的具體使用

    本篇文章主要介紹了vue組件jsx語法的具體使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue項(xiàng)目中l(wèi)ess的一些使用小技巧

    vue項(xiàng)目中l(wèi)ess的一些使用小技巧

    前段時間一直在學(xué)習(xí)vue,開始記錄一下遇到的問題,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中l(wèi)ess的一些使用小技巧,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-09-09
  • vue3+ts使用bus事件總線的示例代碼

    vue3+ts使用bus事件總線的示例代碼

    這篇文章主要介紹了vue3+ts使用bus事件總線,文中給大家提到了vue總線機(jī)制(bus)的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • Vue3如何使用Vue-Router進(jìn)行路由控制

    Vue3如何使用Vue-Router進(jìn)行路由控制

    無論是小型項(xiàng)目還是中大型項(xiàng)目,Vue-Router都是必選的一個組件,Vue-Router提供了便捷的方式進(jìn)行路由跳轉(zhuǎn),在使用過程中有一些坑,希望能給在編碼找不到問題時的碼農(nóng)提供一點(diǎn)靈感
    2022-06-06
  • Vue.directive自定義指令的使用詳解

    Vue.directive自定義指令的使用詳解

    本篇文章主要介紹了Vue.directive自定義指令的使用詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Vue中子組件向父組件傳值以及.sync修飾符詳析

    Vue中子組件向父組件傳值以及.sync修飾符詳析

    .sync?修飾符所提供的功能,當(dāng)一個子組件改變了一個prop的值時,這個變化也會同步到父組件中所綁定,下面這篇文章主要給大家介紹了關(guān)于Vue中子組件向父組件傳值以及.sync修飾符的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • vue實(shí)現(xiàn)循環(huán)滾動列表

    vue實(shí)現(xiàn)循環(huán)滾動列表

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)循環(huán)滾動列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • VUE長按事件需求詳解

    VUE長按事件需求詳解

    這篇文章主要為大家詳細(xì)介紹了為大家詳細(xì)幾種長按事件的需求,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • VUE 使用中踩過的坑

    VUE 使用中踩過的坑

    本篇是我對vue使用過程中以及對一些社區(qū)朋友提問我的問題中做的一些總結(jié),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-02-02

最新評論