1 修改ruoyi-generator下resources下vm.java.controller
@PostMapping("/importTemplate")
public void importTemplate(HttpServletResponse response)
{
ExcelUtil<${
ClassName}> util = new ExcelUtil<${
ClassName}>(${
ClassName}.class);
util.importTemplateExcel(response, "${functionName}数据");
}
@Log(title = "${functionName}", businessType = BusinessType.IMPORT)
@PreAuthorize("@ss.hasPermi('${permissionPrefix}:import')")
@PostMapping("/importData")
public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception
{
ExcelUtil<${
ClassName}> util = new ExcelUtil<${
ClassName}>(${
ClassName}.class);
List<${
ClassName}> list = util.importExcel(file.getInputStream());
int count = 0;
for (${
ClassName} ${
className} : list) {
int i = ${
className}Service.insert${
ClassName}(${
className});
count = count + i;
}
return AjaxResult.success("导入成功" + count + "条信息!");
}
2 修改vue下index.vue.vm文件
importTemplate() {
this.download('${moduleName}/${businessName}/importTemplate', {
}, `template_#[[${
new Date().getTime()}]]#.xlsx`)
},
handleImport() {
this.upload.title = "${functionName}导入";
this.upload.open = true;
},
handleFileUploadProgress(event, file, fileList) {
this.upload.isUploading = true;
},
handleFileSuccess(response, file, fileList) {
this.upload.open = false;
this.upload.isUploading = false;
this.$refs.upload.clearFiles();
this.$alert("<div style='overflow: auto;overflow-x: hidden;max-height: 70vh;padding: 10px 20px 0;'>" + response.msg + "</div>", "导入结果", {
dangerouslyUseHTMLString: true });
this.getList();
},
submitFileForm() {
this.$refs.upload.submit();
}
upload: {
open: false,
title: "",
isUploading: false,
updateSupport: 0,
headers: {
Authorization: "Bearer " + getToken() },
url: process.env.VUE_APP_BASE_API + "/${moduleName}/${businessName}/importData"
},
<!-- 导入对话框 -->
<el-dialog :title="upload.title" :visible.sync="upload.open" width="400px" append-to-body>
<el-upload
ref="upload"
:limit="1"
accept=".xlsx, .xls"
:headers="upload.headers"
:action="upload.url + '?updateSupport=' + upload.updateSupport"
:disabled="upload.isUploading"
:on-progress="handleFileUploadProgress"
:on-success="handleFileSuccess"
:auto-upload="false"
drag
>
<i class="el-icon-upload"></i>
<div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
<div class="el-upload__tip text-center" slot="tip">
<div class="el-upload__tip" slot="tip">
<el-checkbox v-model="upload.updateSupport" /> 是否更新已经存在的数据
</div>
<span>仅允许导入xls、xlsx格式文件。</span>
<el-link type="primary" :underline="false" style="font-size:12px;vertical-align: baseline;" @click="importTemplate">下载模板</el-link>
</div>
</el-upload>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitFileForm">确 定</el-button>
<el-button @click="upload.open = false">取 消</el-button>
</div>
</el-dialog>
import {
getToken} from "@/utils/auth";