用户登录
用户注册

分享至

Vue axios 中提交表单数据(含上传文件)

  • 作者: 正宗卖男孩的小火柴
  • 来源: 51数据库
  • 2022-05-22

我们经常使用表单来上传数据,以及上传文件,那么怎么在表单提交成功的时候接受服务器的响应,并作出相应操作.

当然使用一般jquery上传对象的格式也是可以的,如果使用传统的表单上传呢?

<!doctype html>
<html lang="en">
  <head>
    <title></title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
  </head>
  <body>
    <form method="post" action="/upload" enctype="multipart/form-data">
      <input type="text" name="name" value="" placeholder="请输入用户名">
      <input type="text" name="age" value="" placeholder="请输入年龄">
      <input type="file" name="uploadfile">
      <input type="submit" value="提交">
    </form>
  </body>
</html>

这种方式可以提交,那么问题来了,表单提交以后如果需要获取服务器的响应呢,如果需要在响应成功后跳转页面呢,这种方式显得不好处理.

切回正题,在vue中这种简单的表单提交如何处理呢,其实使用的是 formdata 来模拟表单提交

<head>
  <title></title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <script src="http://www.51sjk.com/Upload/Articles/1/0/312/312485_20210808000309990.js"></script>
  <script src="http://www.51sjk.com/Upload/Articles/1/0/312/312485_20210808000310303.js"></script>
</head>

<body>
  <form>
    <input type="text" value="" v-model="name" placeholder="请输入用户名">
    <input type="text" value="" v-model="age" placeholder="请输入年龄">
    <input type="file" @change="getfile($event)">
    <button @click="submitform($event)">提交</button>
  </form>

  <script>
    window.onload = function () {
      vue.prototype.$http = axios;
      new vue({
        el: 'form',
        data: {
          name: '',
          age: '',
          file: ''
        },
        methods: {
          getfile(event) {
            this.file = event.target.files[0];
            console.log(this.file);
          },
          submitform(event) {
            event.preventdefault();
            let formdata = new formdata();
            formdata.append('name', this.name);
            formdata.append('age', this.age);
            formdata.append('file', this.file);

            let config = {
              headers: {
                'content-type': 'multipart/form-data'
              }
            }

            this.$http.post('/upload', formdata, config).then(function (res) {
              if (res.status === 2000) {
                /*这里做处理*/
              }
            })
          }
        }
      })
    }
  </script>
</body>

</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

软件
前端设计
程序设计
Java相关