VUE3-form表单保存附件与基本信息

element-ui代码

<el-dialog :title="上传附件" v-model="dialogAdds.visible" width="500px" append-to-body>

<el-form-item label="唯一标识">

<dict-tag v-if="form.groupId" :options="unique_identification" :value="form.identification" />

<el-input v-else v-model="form.identification" disabled style="width:260px;" />

</el-form-item>

<el-form-item label="设备" prop="file">

<template #default>

<div>

<div>

<label for="fileUpload">

<div class="lBut"><span>选择文件</span></div>

</label>

<div class="el-upload__tip text-red">允许上传.xls .xlsx</div>

<input id="fileUpload" type="file" style="display: none;" accept=".xls,.xlsx" @change="handleFileChange" />

<div class="el-upload__tip text-red" v-if="uploadFileName">{{ uploadFileName }}</div>

</div>

</div>

</template>

</el-form-item>

</el-form>

<template #footer>

<div class="dialog-footer">

<el-button :loading="buttonLoading" type="primary" @click="submitFormMul">确 定</el-button>

<el-button @click="cancelAdds">取 消</el-button>

</div>

</template>

</el-dialog>

js代码

<script setup lang="ts">

import axios from 'axios';

const dialogAdds = reactive<DialogOption>({

visible: false,

title: ''

});

// 文件上传

const handleFileChange = (event:any) => {

if(event.target.files[0].size > 1024*1024*40){

return proxy?.$modal.msgSuccess("上传文件不能大于40M");

}

// 附件名称

uploadFileName.value=event.target.files[0].name;

form.value.file= event.target.files[0];

}

// 保存操作

const submitFormMul = ()=>{

deviceFormRef.value?.validate(async (valid: boolean) => {

if (valid) {

buttonLoading.value = true;

const result=await axios.post(import.meta.env.VITE_APP_BASE_API+'/device/device/deviceImportByExcel', form.value, {

headers: {

'Content-Type': 'multipart/form-data',

},

});

if(result.data.code==601){

proxy?.$modal.alertErrorTitle(result.data.data,"导入错误提示");

}

// 重置

uploadFileName.value='';

dialogAdds.visible = false;

buttonLoading.value = false;

}

});

}

</script>

style样式

<style>

.lBut{

width: 87px;

height: 32px;

font-size: 14px;

line-height: 1.15;

display: flex;

justify-content: center;

align-items: center;

border-radius: 4px;

padding: 8px 10px;

margin-left: 2px;

transition: all 0.5s;

white-space: nowrap;

background-color: #409eff;

color: white;

border: 1px solid #409eff;

}

</style>

结果展示

相关推荐
用户6175171570140 分钟前
关于普通函数和箭头函数的this
javascript
RPGMZ1 小时前
RPGMakerMZ 地图存档点制作 标题继续游戏直接读取存档
开发语言·javascript·游戏·游戏引擎·rpgmz·rpgmakermz
有一个好名字2 小时前
Agent Loop —— 一切从那个 while 循环开始
前端·javascript·chrome
EF@蛐蛐堂2 小时前
【js】浏览器滚动条优化组件OverlayScrollbars
开发语言·javascript·ecmascript
辰同学ovo2 小时前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
爱看书的小沐3 小时前
【小沐杂货铺】基于Three.js绘制三维艺术画廊3DArtGallery (Three.js,WebGL)
javascript·3d·webgl·three.js·babylon.js·三维画廊
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_12:(HTML网页图片嵌入)
前端·javascript·css·ui·html
是上好佳佳佳呀4 小时前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
你真的快乐吗4 小时前
@fuxishi/svg-icon:一个 Vue 3 svg本地图标+iconify图标组件库,让图标管理不再头疼
前端·vue.js·typescript
Rkgua4 小时前
ESModule和Commonjs模块的区别
前端·javascript