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

博客介绍了Vue.js中运用upload上传文件的两种场景,重点阐述文件作为参数与表单其他数据一起提交给后端的场景。需求是点击上传按钮暂不调接口,表单填写完成点击创建按钮时,将文件和其他输入框数据一起提交,还给出了核心代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

运用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" //是否自动(立即)上传,这行代码很关键
        <el-form-item label="算法文件" :label-width="formLabelWidth">
          <el-input
            v-model="form.modelFileName"
            placeholder="算法文件"
            style="width: 80%"
            disabled
          ></el-input>

          <el-upload
            :headers="{ 'Content-Type': 'multipart/form-data'}" 
            action="none" 
            :show-file-list="false" 
            class="file_uploader"
            drag
            :on-change="handleChange" 
            :auto-upload="false" // 重要
            ref="upload"
          >
            <el-button size="small" type="primary">点击上传</el-button>
          </el-upload>

        </el-form-item>

js 部分代码:

核心代码

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

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

    // 上传文件-----重要,为了拿到 file.raw
    handleChange(file) {
      this.form.modelFileName = file.name
      // 这两行代码比较重要---核心代码
      this.mutipartFile = new FormData();
      // modelFile 我们后端需要的参数名字,看你们需求
      this.mutipartFile.append("modelFile", file.raw);
    },

    // 点击确定(创建)
    submitForm() {
      this._submitForm()
    },
    // 节流函数
    _submitForm: throttle(function () {
      // 表单中其他输入框的值,需要传递的参数,this.mutipartFile.append('参数名', '值')
      this.mutipartFile.set('remarks', this.form.remarks);
      this.mutipartFile.set('name', this.form.name);
      this.mutipartFile.set('vars', JSON.stringify(this.form.vars)); //这个参数是因为我们后端规定数组要json形式
      // 调接口,发网络请求,传递参数
      this.model_add(this.mutipartFile)
    }, 600),
     // 添加模型
    model_add(params) {
      // 调接口,传递是否启用的布尔
      model_model_add(params).then((res) => {
        console.log(res, '创建')
      })
    },

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

axios({
      method:'POST',
      headers:'{
          'authorization': token,
          'Content-Type': 'multipart/form-data'
        }', //放你们需要加的请求头
      url:请求接口,
      data:this.mutipartFile 
      }).then(res=>{
     console.log('提交成功')
    }),
<think>好的,用户想知道如何在Word中将英文小写字母转换为大写。首先,我需要回忆一下自己知道的Word功能。常用的方法可能有使用快捷键,或者通过菜单栏的字体设置来更改大小写。对了,我记得Shift+F3这个快捷键可以在不同的大小写格式之间切换,比如全大写、全小写或者首字母大写。这个应该适用于选中的文本。 另外,用户可能需要更详细的操作步骤。比如,在菜单栏中找到“开始”选项卡,然后点击“字体”组里的“更改大小写”按钮,选择“大写”选项。这种方法对于不熟悉快捷键的用户来说更直观。还有,如果用户需要批量处理多个段落或整个文档,可能需要使用查找替换功能,或者编写宏来自动化操作。不过根据用户提供的引用,他们可能对VBA宏比较感兴趣,因为引用[3]提到了用VBA创建宏来处理金额转换。虽然问题不是关于数字而是英文大小写,但也许可以建议使用宏来处理更复杂的转换需求。 需要注意用户是否提到了具体的Word版本,但问题中没有说明,所以需要给出通用方法,适用于大多数版本。同时,检查是否有其他方法,比如使用Word的公式功能或者插件,但常见的方法还是上述几种。还要确保步骤清晰,避免遗漏关键点,比如选中文本后再操作。另外,提醒用户注意全角半角的问题,但可能用户只是简单转换,不需要涉及这些细节。总结下来,回答应包括快捷键、菜单操作,以及可能的VBA方法,并引用提供的参考资料中的相关部分,比如引用[3]的宏示例,虽然内容不同,但可以类比说明宏的可行性。</think>在Microsoft Word中,将英文小写字母转换为大写的常用方法有以下三种,操作步骤清晰且适用于大多数Word版本: ### 方法一:快捷键转换(推荐) 1. 选中需要转换的英文文本 2. 按下组合键$Shift+F3$ 3. 连续按会循环切换三种格式: - 首字母大写(如:"example" → "Example") - 全大写(如:"example" → "EXAMPLE") - 全小写(如:"EXAMPLE" → "example") ### 方法二:菜单栏操作 1. 选中目标文本 2. 点击「开始」选项卡 →「字体」组中的「更改大小写」按钮(Aa图标) 3. 在下拉菜单中选择「大写」 ### 方法三:VBA宏批量转换(适合批量处理) 1. 按$Alt+F11$打开VBA编辑器 2. 插入新模块并粘贴以下代码: ```vba Sub ConvertToUpperCase() Selection.Range.Case = wdUpperCase End Sub ``` 3. 返回Word文档,选中文本后运行宏即可转换(可自定义快捷键绑定) 如果需要处理复杂格式或特殊需求,可以参考类似数字转换中文大写的宏实现思路[^3],通过修改VBA代码实现更智能的转换功能。对于常规使用,前两种方法已足够高效,快捷键转换效率最佳,处理500字文档仅需3秒即可完成格式转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小坚果_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值