Element-UI 自定義upload組件(進度條,刪除,下載)

先看看效果圖


上傳過程中.png

上傳結束后.png

代碼也很簡單,樣式自己寫好之后就剩下處理進度條了

             <div class="footer">
                    <div class="title">
                        <span>產品資料</span>
                        <span>(提示:文件請控制大小在10MB以內)</span>
                        <el-upload 
                            multiple//多文件上傳
                            :action="uploadUrl" //文件上傳的地址(必填)
                            :show-file-list="false" //自定義樣式所以設置false不顯示
                            :file-list="fileArr"http://文件列表
                            :before-upload="beforeUploadFile" //文件上傳前
                            :on-progress="uploadFileProcess" //文件傳輸過程(處理進度條)
                            :on-success="handleFileSuccess" //文件成功
                            >
                            <el-button size="small" type="primary">瀏覽</el-button>
                        </el-upload>   
                    </div>
                    <div class="file">
                        <div  v-for="(item,index) in fileArr" :key="index">
                            <span><i class="bg"></i>{{item.name}}</span>
                            <div  v-if="item.progressFlag">
                                <el-progress :percentage="item.progressPercent"></el-progress>
                            </div>
                            <span v-else-if="item.successFlag">上傳成功!</span>
                            <span v-else>上傳失敗!</span>
                            <span>{{item.size | fileSize}}</span>
                            <div v-if="item.progressFlag">
                                <span>[刪除]</span>
                                <span>[下載]</span>
                            </div>
                            <div v-else>
                                <span @click="removeFile(item,index)">[刪除]</span>
                                <span @click="downLoadFile(item,index)">[下載]</span>
                            </div>
                        </div>
                    </div>
                </div>

methods部分

    <---文件上傳部分-->
     //上傳前的函數(shù)(用于驗證上傳文件格式及大小)
        beforeUploadFile(file){
            const isLt10M = file.size / 1024 / 1024 < 10;
            if (!isLt10M) {
              return false;
            }
        },
    //文件上傳過程中的函數(shù)(在這里獲取進度條的進度)
        uploadFileProcess(event, file, fileList){
            this.fileArr = fileList
            this.fileArr.forEach(item=>{
                if (item.percentage == 100) {

                } else {
                  item.progressFlag = true
                  item.progressPercent = Math.abs(item.percentage.toFixed(0));
                }
            })
        },
    //文件上傳成功的函數(shù)(用于文件上傳成功之后的邏輯)
        handleFileSuccess(res, file,fileList){
            this.fileArr = fileList
            this.fileArr.forEach((item,index)=>{
                item.progressFlag = false
                if(item.status == 'success'){
                    item.successFlag = true
                }else{
                    item.successFlag = false
                }
            })
        },
        //刪除文件(基于文件列表的數(shù)據(jù)進行操作)
        removeFile(item,index){
            this.fileArr.splice(index,1)
        },
        //下載文件(基于文件列表的數(shù)據(jù)進行操作)
        downLoadFile(item,index){
            
        }
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子钮热,更是在濱河造成了極大的恐慌蚁飒,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渣淤,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機乎折,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來侵歇,“玉大人骂澄,你說我怎么就攤上這事√杪牵” “怎么了坟冲?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長溃蔫。 經常有香客問我健提,道長,這世上最難降的妖魔是什么伟叛? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任矩桂,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘侄榴。我一直安慰自己雹锣,他們只是感情好,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布癞蚕。 她就那樣靜靜地躺著蕊爵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桦山。 梳的紋絲不亂的頭發(fā)上攒射,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天,我揣著相機與錄音恒水,去河邊找鬼会放。 笑死,一個胖子當著我的面吹牛钉凌,可吹牛的內容都是我干的咧最。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼御雕,長吁一口氣:“原來是場噩夢啊……” “哼矢沿!你這毒婦竟也來了?” 一聲冷哼從身側響起酸纲,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤捣鲸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后闽坡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體栽惶,經...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年疾嗅,在試婚紗的時候發(fā)現(xiàn)自己被綠了媒役。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡宪迟,死狀恐怖酣衷,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情次泽,我是刑警寧澤穿仪,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站意荤,受9級特大地震影響啊片,放射性物質發(fā)生泄漏。R本人自食惡果不足惜玖像,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一紫谷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦笤昨、人聲如沸祖驱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽捺僻。三九已至,卻和暖如春崇裁,著一層夾襖步出監(jiān)牢的瞬間匕坯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工拔稳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留葛峻,地道東北人。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓巴比,卻偏偏與公主長得像术奖,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子匿辩,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內容