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 相关文章推荐
传递参数的标准方法(jQuery.ajax)
Nov 19 Javascript
JavaScript Konami Code 实现代码
Jul 29 Javascript
jquery validation插件表单验证的一个例子
Mar 03 Javascript
用jquery实现的模拟QQ邮箱里的收件人选取及其他效果(一)
Jan 06 Javascript
提升PHP安全:8个必须修改的PHP默认配置
Nov 17 Javascript
3种js实现string的substring方法
Nov 09 Javascript
理解jquery事件冒泡
Jan 03 Javascript
JavaScript简单下拉菜单特效
Sep 13 Javascript
JS+HTML5 FileReader对象用法示例
Apr 07 Javascript
对于input 框限定输入值为浮点型的js代码
Sep 25 Javascript
javascript 产生随机数的几种方法总结
Sep 26 Javascript
jQuery实现的简单歌词滚动功能示例
Jan 07 jQuery
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
地摊中国 - 珍藏老照片
2020/08/18 杂记
PHP simple_html_dom.php+正则 采集文章代码
2009/12/24 PHP
php实现读取超大文件的方法
2014/07/28 PHP
详解PHP数据压缩、加解密(pack, unpack)
2016/12/17 PHP
escape、encodeURI 和 encodeURIComponent 的区别
2009/03/02 Javascript
checkbox 复选框不能为空
2009/07/11 Javascript
用js来刷新当前页面保留参数的具体实现
2013/12/23 Javascript
JavaScript截取字符串的2个函数介绍
2014/08/27 Javascript
Javascript学习笔记之相等符号与严格相等符号
2014/11/23 Javascript
jQuery模拟新浪微博首页滚动效果的方法
2015/03/11 Javascript
基于javascript制作经典传统的拼图游戏
2016/03/22 Javascript
JavaScript知识点总结(四)之逻辑OR运算符详解
2016/05/31 Javascript
jquery仿苹果的时间/日期选择效果
2017/03/08 Javascript
JS传参及动态修改页面布局
2017/04/13 Javascript
weebox弹出窗口不居中显示的解决方法
2017/11/27 Javascript
详解vue-cli项目中怎么使用mock数据
2018/05/29 Javascript
说说Vue.js中的functional函数化组件的使用
2019/02/12 Javascript
利用webpack理解CommonJS和ES Modules的差异区别
2020/06/16 Javascript
JS实现简单打字测试
2020/06/24 Javascript
在Python中操作列表之list.extend()方法的使用
2015/05/20 Python
利用python实现数据分析
2017/01/11 Python
Python django框架应用中实现获取访问者ip地址示例
2019/05/17 Python
12个Python程序员面试必备问题与答案(小结)
2019/06/24 Python
使用Python自动生成HTML的方法示例
2019/08/06 Python
自定义Django Form中choicefield下拉菜单选取数据库内容实例
2020/03/13 Python
Python 求向量的余弦值操作
2021/03/04 Python
关于css中margin的值和垂直外边距重叠问题
2020/10/27 HTML / CSS
美国紧身牛仔裤品牌:NYDJ
2017/05/24 全球购物
Hurley官方网站:扎根于海滩生活方式的全球青年文化品牌
2020/05/18 全球购物
设计师求职信模板
2014/05/06 职场文书
高中课前三分钟演讲稿
2014/09/13 职场文书
学习教师敬业奉献模范事迹材料思想汇报
2014/09/19 职场文书
四风问题个人自查剖析材料思想汇报
2014/09/21 职场文书
2014年国庆节演讲稿精选范文1500字
2014/09/25 职场文书
五年级学生期末评语
2014/12/26 职场文书
中学教师个人总结
2015/02/10 职场文书