.net core+Vue Excel文件导入

Vue2.0 文件上传组件代码,弹窗代码(Element.vue)饿了么的ui组件

<el-dialog :visible.sync="showImportRank" width="21%" :append-to-body="true" :title="$t('roster.importRankTitle')">
            <el-upload class="upload-demo" drag :action="uploadHost + '/user/importUserRank'" :limit="1"
                :on-error="handleError" :on-success="handleSuccess" :headers="headObject" :auto-upload="false" ref="upload"
                accept=".xls,.xlsx">
                <i class="el-icon-upload"></i>
                <div class="el-upload__text">{{ $t('roster.putfilehere') }}<em>{{ $t('roster.selectfile') }}</em></div>
                <!--                <div class="el-upload__tip" slot="tip">只能上传excel文件</div>-->
            </el-upload>
            <span slot="footer" class="dialog-footer">
                <el-button size="small" icon="el-icon-upload2" type="success" @click="submitUpload">
                    {{ $t('roster.importServer') }}
                </el-button>
                <el-button size="small" icon="el-icon-download" type="success" @click="downLoadUserRankTemp">
                    {{ $t('roster.downloadTemplate') }}
                </el-button>
            </span>
</el-dialog>

上传文件接口::action="uploadHost + '/user/importUserRank'"

uploadHost:是我自定义的路径

Vue脚本代码:

methods: {
   submitUpload() {
            // 将文件上传到服务器,先触发beforeUpload事件,对上传的文件进行校验,校验通过后才会上传
            this.$refs.upload.submit();
        },
    handleError(res, file) {
            // this.imageUrl = URL.createObjectURL(file.raw);
            this.$message('上传失败');
            this.showImport = false;
            this.$refs.upload.clearFiles();
        },
        handleSuccess(res, file) {
            // this.imageUrl = URL.createObjectURL(file.raw);
            this.$message('上传成功');
            if (res.invalidCount > 0) {//res.invalidCount接口返回的对象
                this.$message(res.invalid,10000);
            }
            this.showImport = false;
            this.$refs.upload.clearFiles();
        },
}

.net core接口代码

/// <summary>
        /// 导入用户岗级
        /// </summary>
        /// <param name="file"></param>
        /// <returns></returns>
        [HttpPost("importUserRank")]
        //[Permission(ModuleCodes.UserList, SimpleOperation.Import)]//模块验证和权限设置
        public Object ImportUserRankExcel(IFormFile file)
        {
            List<int> invalidList = new List<int>();
            List<string> invalErrTxtList = new List<string>();
            if (file?.Length > 0)
            {
                DataTable dt = ExcelHelper.ExcelToDatatable(file.OpenReadStream(), Path.GetExtension(file.FileName), fistRow: 0);
                if (dt.Rows.Count > 0)
                {
                    var importUserlist = ExcelHelper.ConvertTo<UserRankRequest>(dt).ToList();
                    for (int i = 0; i < importUserlist.Count; i++)
                    {
                        var userReq = _userService.GetUserReqByOrgUserId(Convert.ToInt32(importUserlist[i].OrgUserId));
                        if (userReq == null)
                        {
                            invalidList.Add(i);
                            invalErrTxtList.Add(string.Format(_userlocalizer[UserResources.OrgUserIdNotExist], importUserlist[i].OrgUserId));
                            continue;
                        }
                        if (!_rankService.ExistRankCode(importUserlist[i].UserRank))
                        {
                            invalidList.Add(i);
                            invalErrTxtList.Add(string.Format(_ranklocalizer[RankResources.RankLevelCodeNotExist], importUserlist[i].UserRank));
                            continue;
                        }
                        userReq.UserRank = importUserlist[i].UserRank;
                        _userService.UpdateUser(userReq);
                    }
                }
            }

            return new
            {
                invalidCount = invalidList.Count,
                invalid = string.Join(";", invalErrTxtList),
            };
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

新时代丘鸣山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值