• element关于form表单其他参数+upload文件 一起提交


    运用upload有两种场景:

    ①上传文件是个单独的接口,action里就放上传文件的接口地址就可以,然后在成功回调里拿到后端返回的内容(可能是url;也可能是个对象,里边有url和name)。

    ②上传文件没有接口,文件作为某个接口的其中一个参数,和其他参数一起,最后传递给后端,就是今天要说的场景。

    先说我的需求:

    点击上传的蓝色按钮之后,并没有调接口,而是在所有的(其他的)表单填写完成之后 点击下边的 创建 按钮  把其他输入框的数据以及刚刚上传的文件 一起提交给后端,这个时候才会调接口。

    下面这张图就是我的需求图:

     解决:

    templete部分:

    :headers="{ 'Content-Type': 'multipart/form-data'}" //设置请求头,可以有token什么的
    action="none" // action:这个属性是上传文件的地址,当我们指定了 auto-upload 属性, 组件就会自动按 action 的地址提交。不设置这个属性就写  action="none"
    :show-file-list="false"
    class="file_uploader"
    drag  //是否启用拖拽上传
    :on-change="handleChange"  //文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用,function(file, fileList)
    :auto-upload="false" //是否自动(立即)上传,这行代码很关键
    1. <el-form-item label="算法文件" :label-width="formLabelWidth">
    2. <el-input
    3. v-model="form.modelFileName"
    4. placeholder="算法文件"
    5. style="width: 80%"
    6. disabled
    7. ></el-input>
    8. <el-upload
    9. :headers="{ 'Content-Type': 'multipart/form-data'}"
    10. action="none"
    11. :show-file-list="false"
    12. class="file_uploader"
    13. drag
    14. :on-change="handleChange"
    15. :auto-upload="false" // 重要
    16. ref="upload"
    17. >
    18. <el-button size="small" type="primary">点击上传</el-button>
    19. </el-upload>
    20. </el-form-item>

    js 部分代码:

    核心代码

    this.mutipartFile = new FormData();
    this.mutipartFile.append("modelFile", file.raw);

    表单里的其他参数,都以这种形式添加进 this.mutipartFile,this.mutipartFile就是个变量,叫什么都可以,看你自己

    1. // 上传文件-----重要,为了拿到 file.raw
    2. handleChange(file) {
    3. this.form.modelFileName = file.name
    4. // 这两行代码比较重要---核心代码
    5. this.mutipartFile = new FormData();
    6. // modelFile 我们后端需要的参数名字,看你们需求
    7. this.mutipartFile.append("modelFile", file.raw);
    8. },
    9. // 点击确定(创建)
    10. submitForm() {
    11. this._submitForm()
    12. },
    13. // 节流函数
    14. _submitForm: throttle(function () {
    15. // 表单中其他输入框的值,需要传递的参数,this.mutipartFile.append('参数名', '值')
    16. this.mutipartFile.set('remarks', this.form.remarks);
    17. this.mutipartFile.set('name', this.form.name);
    18. this.mutipartFile.set('vars', JSON.stringify(this.form.vars)); //这个参数是因为我们后端规定数组要json形式
    19. // 调接口,发网络请求,传递参数
    20. this.model_add(this.mutipartFile)
    21. }, 600),
    22. // 添加模型
    23. model_add(params) {
    24. // 调接口,传递是否启用的布尔
    25. model_model_add(params).then((res) => {
    26. console.log(res, '创建')
    27. })
    28. },

     网络请求那一块也可以直接这样写

    1. axios({
    2. method:'POST',
    3. headers:'{
    4. 'authorization': token,
    5. 'Content-Type': 'multipart/form-data'
    6. }', //放你们需要加的请求头
    7. url:请求接口,
    8. data:this.mutipartFile
    9. }).then(res=>{
    10. console.log('提交成功')
    11. }),
  • 相关阅读:
    详解欧拉计划第757题:隐匿数
    数据库连接技术
    LeetCode 88. 合并两个有序数组(JavaScript 简单)
    Android Framework通信:Handler
    axios接口请求超时,重试方法
    S3 client向ceph上传文件注意事项
    js实现一个 bind 函数
    Django初窥门径-oauth登录认证
    Profinet协议分布式现场总线IO安装教程2
    搜索引擎-02-分词与全文索引
  • 原文地址:https://blog.csdn.net/m0_61702149/article/details/127570672