elemetUi 组件--el-upload实现上传Excel文件的实例


Posted in Javascript onOctober 27, 2017

elemetUi 组件--el-upload实现上传Excel文件的实例

【需求】实现上传Excel文件,在上传到服务器时,还要附加一个参数,在请求上传文件接口前,先要进行文件格式判断。

elemetUi 组件--el-upload实现上传Excel文件的实例

【知识点】

1、el-upload 官方文档中,主要用到了以下属性:

data 可选参数, 上传时附带的额外参数
name 可选参数, 上传的文件字段名
before-upload 可选参数, 上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。

2、split进行字符串截取

【分析】

<template>
  <div class="panel admin-panel">
    <div class="panel-head" id="add"><strong><span class="el-icon-edit"></span><span class="title">上传数据</span></strong></div>
    <div class="body-content">
      <el-form :model="ruleForm" ref="ruleForm" label-width="100px" class="form uploadform">
        <el-form-item label="部门" prop="name">
          <el-select v-model="form.type" placeholder="请选择" style="width: 135px">
            <el-option
                v-for="item in options"
                :key="item.value"
                :label="item.label"
                :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>

        <el-form-item>

          <el-upload
              class="upload-demo"
              ref="upload"
              action="http://10.1.20.218:8088/gnh-webadmin-platfrom/api/v1/sendSalaryBillGeinihua"
              :on-preview="handlePreview"
              :before-upload="beforeAvatarUpload"
              :on-remove="handleRemove"
              :file-list="fileList"
              :auto-upload = 'false'
              :on-success = 'handleSuccess'
              :data="form"
              name="salaryBill">
            <el-button slot="trigger" size="small" type="primary">选取文件</el-button>
            <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button>
            <div slot="tip" class="el-upload__tip">只能上传xls/xlsx文件</div>
          </el-upload>

        </el-form-item>
      </el-form>
    </div>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        options: [{
          value: '1',
          label: '帅哥部'
        }, {
          value: '2',
          label: '美女部'
        }],
        fileName:'',
        fileList:[],
        ruleForm: {
//          name: '',
          isShow: '0'
        },
        form:{
          type:'1'
        },

      };
    },
    methods: {
      submitUpload() {
        this.$refs.upload.submit();
      },

      beforeAvatarUpload(file) {

        let Xls = file.name.split('.');

        if(Xls[1] === 'xls'||Xls[1] === 'xlsx'){
          return file
        }else {
          this.$message.error('上传文件只能是 xls/xlsx 格式!')
          return false
        }

      },
      handleRemove(file, fileList) {
      },
      handlePreview(file) {
      },
      handleSuccess(res,file,fileList){

        if(res.code===20000){
          this.$message({
            message: '上传成功!',
            type: 'success'
          });
        }else {
          this.$message({
            message: res.msg,
            type: 'error'
          });
        }

      }
    }
  }
</script>
<style scope>
  input[type="file"] {
    display: none;
  }
  .el-upload-list{
    width: 200px;
  }
  .el-select {
    width: 135px;
  }

</style>

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
JScript中的&quot;this&quot;关键字使用方式补充材料
Mar 08 Javascript
HTML node相关的一些资料整理
Jan 01 Javascript
浅谈JavaScript函数参数的可修改性问题
Dec 05 Javascript
Json实现异步请求提交评论无需跳转其他页面
Oct 11 Javascript
jQuery中prev()方法用法实例
Jan 08 Javascript
老生常谈 关于JavaScript的类的继承
Jun 24 Javascript
JavaScript学习笔记整理_setTimeout的应用
Sep 19 Javascript
利用NPM淘宝的node.js镜像加速nvm
Mar 27 Javascript
详解webpack编译多页面vue项目的配置问题
Dec 11 Javascript
详解jQuery中的isPlainObject()使用方法
Feb 27 jQuery
vue侧边栏动态生成下级菜单的方法
Sep 07 Javascript
在vue中实现禁止屏幕滚动,禁止屏幕滑动
Jul 22 Javascript
node 利用进程通信实现Cluster共享内存
Oct 27 #Javascript
vue中v-model动态生成的实例详解
Oct 27 #Javascript
微信小程序 input输入及动态设置按钮的实现
Oct 27 #Javascript
js通过Date对象实现倒计时动画效果
Oct 27 #Javascript
vue-cli + sass 的正确打开方式图文详解
Oct 27 #Javascript
本地搭建微信小程序服务器的实现方法
Oct 27 #Javascript
Vue2.0 axios前后端登陆拦截器(实例讲解)
Oct 27 #Javascript
You might like
77A一级收信机修理记
2021/03/02 无线电
PHP去掉从word直接粘贴过来的没有用格式的函数
2012/10/29 PHP
thinkphp5使用无限极分类
2019/02/18 PHP
laravel csrf排除路由,禁止,关闭指定路由的例子
2019/10/21 PHP
phpQuery采集网页实现代码实例
2020/04/02 PHP
js返回上一页并刷新代码整理
2012/12/21 Javascript
JS实现可改变列宽的table实例
2013/07/02 Javascript
JavaScript二维数组实现的省市联动菜单
2014/05/08 Javascript
jquery实现人性化的有选择性禁用鼠标右键
2014/06/30 Javascript
jquery实现带缩略图的可定制高度画廊效果(5种)
2015/08/28 Javascript
jquery实现模拟百分比进度条渐变效果代码
2015/10/29 Javascript
JS实现表单验证功能(验证手机号是否存在,验证码倒计时)
2016/10/11 Javascript
javascript 闭包详解及简单实例应用
2016/12/31 Javascript
微信小程序 UI与容器组件总结
2017/02/21 Javascript
Jquery中attr与prop的区别详解
2017/05/27 jQuery
解决VUEX刷新的时候出现数据消失
2017/07/03 Javascript
vue template中slot-scope/scope的使用方法
2018/09/06 Javascript
微信小程序静默登录的实现代码
2020/01/08 Javascript
使用Vant完成DatetimePicker 日期的选择器操作
2020/11/12 Javascript
使用Python脚本将绝对url替换为相对url的教程
2015/04/24 Python
Python基于pygame实现图片代替鼠标移动效果
2015/11/11 Python
Python创建二维数组实例(关于list的一个小坑)
2017/11/07 Python
序列化Python对象的方法
2020/08/01 Python
柒牌官方商城:中国男装优秀品牌
2017/06/30 全球购物
乐高奥地利官方商店:LEGO Shop AT
2019/07/16 全球购物
日语专业毕业生求职信
2013/12/04 职场文书
污水厂厂长岗位职责
2014/01/04 职场文书
幼儿园教师教学反思
2014/02/06 职场文书
军训学生自我鉴定
2014/02/12 职场文书
新年抽奖获奖感言
2014/03/02 职场文书
工程造价专业大学生职业规划范文
2014/03/09 职场文书
个人典型事迹材料
2014/12/30 职场文书
公务员个人总结
2015/02/12 职场文书
幼儿园小班教学反思
2016/03/03 职场文书
Go语言带缓冲的通道实现
2021/04/26 Golang
使用Navicat Premium工具将oracle数据库迁移到MySQL
2021/05/27 Oracle