IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> upload控制上传文件类型一致的文件 -> 正文阅读

[JavaScript知识库]upload控制上传文件类型一致的文件

在这里插入图片描述

data() {
    return {
      // 是否是同种文件类型
      IsImgOrFile: null,
      // 是否是图片
      isImage: null,
    };
  },
   // 上传前校检格式
    handleBeforeUpload(file) {
      if(file && file.name){
        var fileName = file.name;
        var fileType = fileName.substring(fileName.lastIndexOf('.')+1);
        var allFileType = ["pdf", "bmp", "webp", "dib", "gif", "jfif", "jpe", "jpeg", "jpg", "png", "tif", "tiff",
          "ico", "pcx", "tga", "exif", "fpx", "svg", "psd", "cdr", "pcd", "dxf", "ufo", "eps", "ai", "raw", "WMF", "avif", "apng"]
         this.isImage = allFileType.includes(fileType)
         if(this.IsImgOrFile == null){
           this.isIMGOrfileFUN()
         }else if(this.IsImgOrFile && this.isImage){
          this.isIMGOrfileFUN()
        }else{
         this.$message.error("请上传文件类型一致的文件")
         return false
        }
      }

    isIMGOrfileFUN(){
      if(this.isImage){  //图片  isImage true
        this.isMultiple = true
        this.showImage = true
        this.limit = 5
        this.IsImgOrFile = true
      }else{  //文件
        this.isMultiple = false
        this.showImage = false
        this.limit = 1
        this.IsImgOrFile = false
      }
    },

图片和文件上传组件完整代码:

 <template>
  <div class="upload-file">
    <!-- 图片列表 -->
    <draggable class="row_wrap" v-if="showImage" @update="dragEvent" animation="300" draggable=".draggable-item">
      <div v-for="(item,imgIndex) in list" :key="imgIndex" class="draggable-item upload-image mr15 mb15">
        <el-image :src="item" :preview-src-list="list" fit="cover" :class="[isSquare?'square-image':'rectangle-image']"></el-image>
        <li class="el-icon-delete" @click.stop="removeImage(imgIndex)"></li>
      </div>
    </draggable>
    <!-- 文件列表 -->
    <transition-group class="upload-file-list el-upload-list el-upload-list--text" name="el-fade-in-linear" tag="ul" v-else>
      <li :key="index" class="el-upload-list__item ele-upload-list__item-content" v-for="(file, index) in list">
        <el-link :href="file" target="_blank">
          <span class="el-icon-document"> {{(file) }} </span>
        </el-link>
        <div class="ele-upload-list__item-content-action">
          <el-link @click="handleDelete(index)" type="danger">删除</el-link>
        </div>
      </li>
    </transition-group>
    <el-upload :action="uploadFileUrl" :before-upload="handleBeforeUpload" :limit="limit"  :on-error="handleUploadError" :on-exceed="handleExceed" :on-success="handleUploadSuccess" :show-file-list="false" :headers="headers" class="upload-file-uploader" ref="upload" v-if="list.length < limit" :multiple="isMultiple">
      <!-- 上传按钮 -->
      <el-button size="mini" type="primary">选取文件</el-button>
    </el-upload>
    <span class="font-xs text-grey">不超过{{limit}}{{isImage ? "张":"个"}}</span>
  </div>
</template>
<script>
import { getToken, getTenantId } from "@/utils/auth";
import draggable from "vuedraggable"
export default {
  components: {
    draggable
  },
  props: {
    // 值
    value: [String, Object, Array],
    // 大小限制(MB)
    fileSize: {
      type: Number,
      default: 5,
    },
    // 是否显示提示
    isShowTip: {
      type: Boolean,
      default: true,
    },
    teacherFileList: {
      type: Array,
    },
     isSquare: {
      type: Boolean,
      default: true,
    },
  },
  data() {
    return {
      uploadFileUrl: process.env.VUE_APP_BASE_API + "/file/uploadDocument", // 上传的图片服务器地址
      headers: {
        Authorization: "Bearer " + getToken(),
        'tenantid': getTenantId(),
        'waterMark': 0,
      },
      limit:5,
      // 是否可以多选
      isMultiple:false,
      // 是否显示图片回显·
      showImage:true,
      // 文件列表
      list: [],
      // 是否是同种文件类型
      IsImgOrFile: null,
      // 是否是图片
      isImage: null,
    };
  },
  methods: {
    // 图片拖动事件
    dragEvent(item) {
      let oldIndexImg = this.list[item.oldDraggableIndex] //拖动的当前的图片
      let navIndexImg = this.list[item.newDraggableIndex] //被换位子的图片
      // 位置替换
      this.list[item.oldDraggableIndex] = navIndexImg;
      this.list[item.newDraggableIndex] = oldIndexImg;
    },
    // 上传前校检格式
    handleBeforeUpload(file) {
      if(file && file.name){
        var fileName = file.name;
        var fileType = fileName.substring(fileName.lastIndexOf('.')+1);
        var allFileType = ["pdf", "bmp", "webp", "dib", "gif", "jfif", "jpe", "jpeg", "jpg", "png", "tif", "tiff",
          "ico", "pcx", "tga", "exif", "fpx", "svg", "psd", "cdr", "pcd", "dxf", "ufo", "eps", "ai", "raw", "WMF", "avif", "apng"]
         this.isImage = allFileType.includes(fileType)
         if(this.IsImgOrFile == null){
           this.isIMGOrfileFUN()
         }else if(this.IsImgOrFile && this.isImage){
          this.isIMGOrfileFUN()
        }else{
         this.$message.error("请上传文件类型一致的文件")
         return false
        }
      }
      // 校检文件大小
      if (this.fileSize) {
        const isLt = file.size / 1024 / 1024 < this.fileSize;
        if (!isLt) {
          this.$message.error(`上传文件大小不能超过 ${this.fileSize} MB!`);
          return false;
        }
      }
      return true;
    },
    isIMGOrfileFUN(){
      if(this.isImage){  //图片  isImage true
        this.isMultiple = true
        this.showImage = true
        this.limit = 5
        this.IsImgOrFile = true
      }else{  //文件
        this.isMultiple = false
        this.showImage = false
        this.limit = 1
        this.IsImgOrFile = false
      }
    },
    // 文件个数超出
    handleExceed() {
      this.$message.error("上传文件个数最多不超过"+this.limit+"个");
    },
    // 上传失败
    handleUploadError(err) {
      this.$message.error("上传失败, 请重试");
    },
    // 上传成功回调
    handleUploadSuccess(res, file) {
      if (res.code !== 200) {
          this.$message.error(`${res.msg}`);
        } else {
          this.list.push(res.data.url);
          this.$emit("input", this.list);
          this.$message.success("上传成功");
        }
    },
    // 删除文件
    handleDelete(index) {
      this.list.splice(index, 1);
      this.IsImgOrFileStart()
    },

    // 删除图片
    removeImage(i) {
      this.list.splice(i, 1);
      this.IsImgOrFileStart()
    },
    // IsImgOrFile变为初始值
    IsImgOrFileStart(){
       if(this.list.length == 0){
        this.IsImgOrFile = null
      }
    }
  },
   watch: {
    value(newVal, oldVal) {
      this.list = newVal;
    },
    waterMark(newVal, oldVal) {
      this.headers.waterMark = newVal;
    }
  },
};
</script>

<style scoped lang="scss">
.upload-file-list .el-upload-list__item {
  border: 1px solid #e4e7ed;
  line-height: 2;
  margin: 2px 0 8px 0px;
  position: relative;
}
.upload-file-list .ele-upload-list__item-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: inherit;
}
.ele-upload-list__item-content-action .el-link {
  margin-right: 10px;
}

.square-image {
  width: 160px;
  height: 160px;
}
.rectangle-image {
  width: 160px;
  height: auto;
}

.upload-image {
  position: relative;
  img {
    border: 1px solid #efefef;
    border-radius: 5px;
  }
  li {
    position: absolute;
    padding: 4px;
    top: 0px;
    right: 0px;
    font-size: 19px;
    border-top-right-radius: 5px;
    border-bottom-left-radius: 5px;
    color: #999;
    background-color: #fafafa;
    cursor: pointer;
  }
}
.draggable-item {
  background: transparent !important;
}
</style>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:20:29  更:2022-04-24 09:20:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 23:22:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码