DDR爱好者之家 Design By 杰米
说在前面
网上有很多种文件上传的方法,根据公司最近的业务需求,要求实现多种文件的上传,在实现过程中,查阅了很多资料,最后,终于把功能实现了,开心!
<template> <div> <v-header :left-text="`上传${columnName}`"></v-header> <div class="upload"> <div v-if="columnName === '视频'"> <div class="forPreview_video" v-for="(item, index) in uploadVideoList" :key="index"> <video :src="/UploadFiles/2021-04-02/videoSrc">上述html代码是在同一页面根据前一页面传回的columnName的值来判断需要上传哪种类型文件。
<script> import VHeader from '../../common/header' import {classifyList, uploadFile, addResources} from '../../http/mock' import Toast from 'vant' export default { name: "uploadFile", components: { VHeader }, data(){ return{ tagList: [], uploadTitle: '', currentTag: null, tagId: null, columnName: localStorage.getItem('columnName'), fileIdArr: [], uploadVideoList: [], // 选中的上传视频列表 videoSrc: '', // 选中的视频的src,用来显示视频 uploadDocList: [], // 选中的上传文档列表 uploadAudioList: [], // 选中的上传音频列表 uploadPicList: [], // 选中的上传图片列表 picSrc: '', // 选中的图片的src,用来显示图片缩略图 } }, filters: { formatSize(val) { // 格式化文件大小 if (val > 0) { return (val / 1024 / 1024).toFixed(2) + 'M'; } else { return '0M'; } }, }, methods: { // vant上传文件前校验文件事件 // 文件选中后先提交给后台,后台根据选中的文件,返回数组(这一业务根据后台而定) beforeRead(file){ let formData = new FormData(); // 为上传文件定义一个formData对象 let config = { headers: { 'Content-Type': 'multipart/form-data' } }; let uploadUrl = URL.createObjectURL(file); // 将选中的上传文件转化为二进制文件,显示在页面上 if(this.columnName === '视频'){ this.uploadVideoList.push(file); this.videoSrc = uploadUrl; // 这里使用foreach是为了将选中的多个文件都添加进定义的formdata变量中 this.uploadVideoList.forEach(item => { formData.append(item.name, item) }) }else if(this.columnName === '文档'){ this.uploadDocList.push(file); this.uploadDocList.forEach(item => { formData.append(item.name, item) }) }else if(this.columnName === '音频'){ this.uploadAudioList.push(file); this.uploadAudioList.forEach(item => { formData.append(item.name, item) }) }else if(this.columnName === '图片'){ this.uploadPicList.push(file); this.picSrc = uploadUrl; this.uploadPicList.forEach(item => { formData.append(item.name, item) }) } // formData.append(file.name, file); // 单个文件上传时可以这么写,上面的foreach就可以删掉 this.$api.post(uploadFile, formData, config).then(res => { this.fileIdArr = res.data.data; // 把選中的文件傳送給後台 }).catch(err => { Toast('文件上傳失敗!') }) }, // 删除待上传的文件 delBtn(index){ if(this.columnName === '视频'){ // 先判断当前的选中的索引是否是在有效范围中,如果不是则跳出方法 if(isNaN(index) || index >= this.uploadVideoList.length){ return false; } let tmp = []; // 将没被选中的上传文件存放进一个临时数组中 for(let i = 0; i < this.uploadVideoList.length; i++){ if(this.uploadVideoList[i] !== this.uploadVideoList[index]){ tmp.push(this.uploadVideoList[i]); } } // 存放当前未被选中的上传文件 this.uploadVideoList = tmp; } if(this.columnName === '文档'){ console.log(this.uploadDocList.length) if(isNaN(index) || index >= this.uploadDocList.length){ return false; } let tmp = []; for(let i = 0; i < this.uploadDocList.length; i++){ if(this.uploadDocList[i] !== this.uploadDocList[index]){ tmp.push(this.uploadDocList[i]); } } this.uploadDocList = tmp; } if(this.columnName === '音频'){ if(isNaN(index) || index >= this.uploadAudioList.length){ return false; } let tmp = []; for(let i = 0; i < this.uploadAudioList.length; i++){ if(this.uploadAudioList[i] !== this.uploadAudioList[index]){ tmp.push(this.uploadAudioList[i]); } } this.uploadAudioList = tmp; } if(this.columnName === '图片'){ if(isNaN(index) || index >= this.uploadPicList.length){ return false; } console.log('uuu') let tmp = []; for(let i = 0; i < this.uploadPicList.length; i++){ if(this.uploadPicList[i] !== this.uploadPicList[index]){ tmp.push(this.uploadPicList[i]); } } this.uploadPicList = tmp; } }, doSubmit(){ let params = { classify: this.tagId, // 针对视频资源时对应的分类id file: this.fileIdArr, // 选择完文件后,调用uploadFile这个接口,后端返回的数组 resourceColumnId: JSON.parse(localStorage.getItem('columnId')), // 资源栏目id(视频、图片、音频、文档) title: this.uploadTitle // 上传时填写的标题 }; let columnName = localStorage.getItem('columnName') this.$api.post(addResources, params).then(res => { if(res.data.code === 1001){ if(columnName === '视频'){ this.$router.push({name: 'myVideo'}); }else { this.$router.push({name: 'myResourceClassify'}); } } }).catch(err => { console.log(err) }) }, }, mounted(){ this.getClassifyList(); } } </script> <style lang="less" scoped> .upload{ padding: 140px 36px 160px 36px; box-sizing: border-box; } .forPreview_video{ position: relative; /*background: rgba(0,0,0,.7);*/ video{ width: 95%; max-height: 430px; } .delte{ position: absolute; right: 0; bottom: 0; } } .forPreview_doc, .forPreview_audio{ display: flex; margin-bottom: 10px; align-items: center; img{ width: 56px; height: 56px; margin-right: 20px; } span:nth-of-type(1){ flex: 1; } span:nth-of-type(2){ margin-right: 20px; } } .forPreview_pic{ display: flex; align-items: flex-end; img{ width: 160px; height: 160px; } } .diy-detail{ width: 100%; overflow: hidden; .btn{ span{ margin-bottom: 10px; } } .van-cell{ background-color: #F0F0F0; border-radius: 35px; font-size: 26px; height: 69px; line-height: 69px; padding: 0 22px; color: #999; } .van-hairline--top-bottom::after, .van-hairline-unset--top-bottom::after { border-width: 0; } p{ height: 64px; line-height: 64px; font-size: 32px; color: #333; position: relative; padding-left: 16px; } p::before{ position: absolute; top: 0; left: 0; content: '*'; color: #FF0000; } span{ display: inline-block; width: 157px; background: #F0F0F0; border-radius: 35px; color: #999; font-size: 26px; padding: 14px 18px; margin-right: 28px; text-align: center; } .active{ color: #fff; background: linear-gradient(to right,#FD5130,#FA6C34); } } .diy-submit { position: fixed; height: 150px; width: 90%; bottom: 0; background: #fff; .van-button { width: 100%; height: 90px; border-radius: 45px; font-size: 36px; color: #fff; background: linear-gradient(to right, #FD5130, #FA6C34); top: 50%; transform: translate(0, -50%); } .van-button--default { border: none; } } </style>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
2024年11月24日
2024年11月24日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]