demo.vue 文件

<template>
<div class="demo">
<input v-model="importForm.month" type="text" name="month"/>
<input ref="importFile" type="file" name="importFile" @change="handleFileChange" />
<button @click="handleConfimImport">确认导入</button>
</div>
</template> <script>
export default {
name: 'profitLossTree',
components: {},
data(){
return {
importForm: {
month: '',
importFile: '',
},
}
},
computed: {},
watch: {},
methods: { //导入文件改变
handleFileChange(){
console.log(this.$refs.importFile.files[0]);
this.importForm.importFile = this.$refs.importFile.files[0];
// console.log(this.importForm, '改变');
},
// 确认导入
handleConfimImport(name){
/* //提取到 post_formData 方法中
// vue 中使用 window.FormData(),否则会报 'FormData isn't definded'
//创建一个FormData对象,然后通过append() 方法向对象中添加键值对
let formData = new window.FormData();
formData.append("month", this.importForm.month);
formData.append("importFile", this.importForm.importFile);
console.log('formData', formData); //formData中的参数是隐式的直接看不到, 可以通过formData 实例的get方法获取
console.log('formData--month', formData.get('month'));
console.log('formData--importFile', formData.get('importFile'));
this.$post_formData( '/profitLossController/importDataNew',
formData
).then( res => {
this.$Message.success('导入成功!');
}) .catch( error => {
this.$Message.error("请求数据出错");
});
}
*/ this.$post_formData('/profitLossController/importDataNew', {
'month': this.importForm.month ,
'importFile': this.importForm.importFile
}).then( res => {
this.$Message.success('导入成功!');
}) .catch( error => {
this.$Message.error("请求数据出错");
});
},
mounted(){ }
};
</script> <style scoped> </style>

对axios进行封装的http.js文件

import axios from 'axios';
import property from './property'; //引用基础配置文件
import util from './util'; //引用刚才我们创建的util.js文件,并使用getCookie方法
import qs from 'qs';
import Cookies from 'js-cookie';
// axios 配置
axios.defaults.timeout = 30000;
axios.defaults.baseURL = util.api; //这是调用数据接口
axios.defaults.withCredentials = true;
axios.defaults.headers = {
'Content-Type': 'application/json' //设置跨域头部
}; // http request 拦截器,通过这个,我们就可以把Cookie传到后台
axios.interceptors.request.use(
config => {
const token = Cookies.get('user'); //获取Cookie
if (token) {
config.headers.token = token;
// config.params = {'token': token}; //后台接收的参数,后面我们将说明后台如何接收
/**
* 原axios封装的时候对所有的请求请求 进行 JSON 转换,会破坏掉 formdata 提交数据,
* 所以可以通过axios.create() 创建一个新的实例(axiosInstanceNew)进行 formdata提交,见下
*/
config.data = JSON.stringify(config.data);
//将get请求的参数进行序列化,主要处理数组传值问题
config.paramsSerializer = function(params) {
return qs.stringify(params, {indices: false});
}
} else {
if (!util.oneOf(config.url, property.noTokenUrl)) {
location.reload();
}
}
return config;
},
err => {
return Promise.reject(err);
}
); // http response 拦截器
axios.interceptors.response.use(
response => {
//response.data.errCode是我接口返回的值,如果值为2,说明Cookie丢失,然后跳转到登录页,这里根据大家自己的情况来设定
// if(response.data.errCode == 2) {
// router.push({
// path: '/login',
// query: {redirect: router.currentRoute.fullPath} //从哪个页面跳转
// })
// }
return response;
},
error => {
switch (error.response.status) {
case 401:
Cookies.remove('user');
if (!util.oneOf(error.config.url.substring(util.api.length), property.noTokenUrl)) {
location.reload();
}
break;
// case 404:
//
// break;
// case 500:
//
// break;
default:
alert(`请求出错!请求状态码:${error.response.status}。`);
}
return error;
// if(error.response.status == 401){
// //this.$Message.error('32131');
// //util.delCookie('user');
// Cookies.remove('user')
// location.reload();
// }else{
// alert("请求出错!");
// }
//return Promise.reject(error.response.data)
}); export default axios;
// -------------------------------
//创建新的axios
//创建一个新的axios实例
const axiosInstanceNew = axios.create({
baseURL: util.api,
timeout: 30000,
withCredentials: true
}); //新axios实例拦截
// http request 拦截器,通过这个,我们就可以把Cookie传到后台
axiosInstanceNew.interceptors.request.use( config => {
const token = Cookies.get('user'); //获取Cookie
if (token) {
config.headers.token = token;
//将get请求的参数进行序列化,主要处理数组传值问题
config.paramsSerializer = function(params) {
return qs.stringify(params, {indices: false});
}
} else {
if (!util.oneOf(config.url, property.noTokenUrl)) {
location.reload();
}
}
return config;
},
err => {
return Promise.reject(err);
}
); // 新 http response 拦截器
axiosInstanceNew.interceptors.response.use( response => {
//response.data.errCode是我接口返回的值,如果值为2,说明Cookie丢失,然后跳转到登录页,这里根据大家自己的情况来设定
// if(response.data.errCode == 2) {
// router.push({
// path: '/login',
// query: {redirect: router.currentRoute.fullPath} //从哪个页面跳转
// })
// }
return response;
}, error => {
switch (error.response.status) {
case 401:
Cookies.remove('user');
if (!util.oneOf(error.config.url.substring(util.api.length), property.noTokenUrl)) {
location.reload();
}
break;
// case 404:
//
// break;
// case 500:
//
// break;
default:
alert(`请求出错!请求状态码:${error.response.status}。`);
}
return error;
// if(error.response.status == 401){
// //this.$Message.error('32131');
// //util.delCookie('user');
// Cookies.remove('user')
// location.reload();
// }else{
// alert("请求出错!");
// }
//return Promise.reject(error.response.data)
}); /**
* post 请求方法
* @param url
* @param data
* @returns {Promise}
*/
export function post (url, data = {}) {
axios.defaults.withCredentials = true;
return new Promise((resolve, reject) => {
axios.post(url, data)
.then(response => { resolve(response.data);
}, err => { reject(err);
});
});
}
/**
* post 请求方法 提交格式为 formdata
* @param url
* @param data
* @returns {Promise}
*/
export function post_formData (url, data = {}) { // vue 中使用 window.FormData(),否则会报 'FormData isn't definded'
//创建一个FormData对象,然后通过append() 方法向对象中添加键值对
// let formData = new window.FormData();
let formData = new FormData(); //这里是 .js文件
for ( let key in data ){
formData.append( key, data[key]);
} const options = {
method: 'POST',
// headers: { 'content-type': 'application/x-www-form-urlencoded' },
headers: { 'Content-type': 'multipart/form-data' },
// data: qs.stringify(data),
data: formData,
url,
};
return axiosInstanceNew(options);
}

说明:注意上面代码有这行注释的地方

        /**
         * 原axios封装的时候对所有的请求请求 进行 JSON 转换,会破坏掉 formdata 提交数据,
         * 所以可以通过axios.create() 创建一个新的实例(axiosInstanceNew)进行 formdata提交,见下
         */
为什么要创建一个新的axios实例的可以参考这篇文章:
 https://blog.csdn.net/qq_41688165/article/details/80834842 

在main.js中挂载到了vue实例原型上

import { post, post_formData } from './libs/http';
Vue.prototype.$post_formData = post_formData;

这样基本上就可以了。请求时参数直接传入一个对象就可以了。

vue+axios通过formdata提交参数和上传文件的更多相关文章

  1. vue axios使用form-data的形式提交数据的问题

    vue axios使用form-data的形式提交数据vue axios request payload form data由于axios默认发送数据时,数据格式是Request Payload,而并 ...

  2. .Net使用HttpClient以multipart/form-data形式post上传文件及其相关参数

    前言: 本次要讲的是使用.Net HttpClient拼接multipark/form-data形式post上传文件和相关参数,并接收到上传文件成功后返回过来的结果(图片地址,和是否成功).可能有很多 ...

  3. Ajax上传数据和上传文件(三种方式)

    Ajax向后端发送数据可以有三种方式:原生Ajax方式,jQuery Ajax方式,iframe+form 方式(伪造Ajax方式) <!DOCTYPE html> <html la ...

  4. php 下 html5 XHR2 + FormData + File API 上传文件

    FormData的作用: FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单.当然FormData也可以动态的append数据.FormD ...

  5. [实战]MVC5+EF6+MySql企业网盘实战(12)——新建文件夹和上传文件

    写在前面 之前的上传文件的功能,只能上传到根目录,前两篇文章实现了新建文件夹的功能,则这里对上传文件的功能进行适配. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战] ...

  6. vue axios 与 FormData 结合 提交文件 上传文件

    ---再利用Vue.axios.FormData做上传文件时,遇到一个问题,后台虽然接收到请求,但是将文件类型识别成了字符串,所以,web端一直报500,结果是自己大意了. 1.因为使用了new  F ...

  7. vue+axios实现移动端图片上传

    在利用vue做一些H5页面时,或多或少会遇到有图片上传的操作,主要是运用html5里面的input[type=file]来实现,传递到后端的数据是以二进制的格式传递,所以上传图片的请求与普通的请求稍微 ...

  8. element ui axios使用formdata提交数据

    axios({ //formdata提交 headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, transformRequ ...

  9. 传统表单提交文件上传,以及FormData异步ajax上传文件

    传统的文件上传: 只用将form表单的entype修改成multipart/form-data,然后就可以进行文件上传,这种方式常用并且简单. 以下是另一种方式FormData,有时候我们需要ajax ...

随机推荐

  1. Tosca 添加 modules,添加Library,引用重复步骤

    #增加modules modules模块式基础,好像一切都得从modules开始,想下面这样一个简单的login module就建好了 把这个module login 拖到具体的test case上 ...

  2. Shell Script 入门教程

    和 Shell 的区别 Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁. Shell 即是一种命令语言,又是一种程序设计语言. Shell 是指一种应用程序,这个应用程序提 ...

  3. postgre alter命令修改字段

    参考文档:https://www.yiibai.com/postgresql/postgresql_alter_command.html PostgreSQL ALTER TABLE命令用于添加,删除 ...

  4. flutter 右滑返回上一页

    import 'package:flutter/material.dart'; import 'package:flutter_app/pages/SplashScreen.dart'; import ...

  5. centos6的kibana7.1无法启动报错 FATAL Error: /lib64/libc.so.6: version `GLIBC_2.14' not found 升级glibc的问题处理

    centos6的kibana7.1无法启动报错 FATAL  Error: /lib64/libc.so.6: version `GLIBC_2.14' not found 升级glibc的问题处理 ...

  6. pytorch标准化后的图像数据如果反标准化保存

    1.数据处理代码utils.py: 1) # coding:utf- import os import torch.nn as nn import numpy as np import scipy.m ...

  7. aar api 导出

    import fsys; import math; var pidMap = {}; math.randomize(); fsys.enum( "~\lib", "*.* ...

  8. ABAP语法篇1 DATA新用法

    @DATA  按取数指定的字段定义内表结 定义工作区: SELECT SINGLE *          FROM lfbk          INTO @DATA(is_lfbk)          ...

  9. SAP标准屏幕中字段描述增强

    转自:https://www.cnblogs.com/sap-ronny/p/7921817.html如果想要改变标准屏幕中的字段名称,如把物料主数据基本数据元素的名字改为我们想要的名字 . 1.首先 ...

  10. idea中报Can't start Git: git.exe The path to Git executable is probably not valid. Fix it

    解决办法,点解Fix it,或者File ----setting------version control-------git,设置git的可执行文件路径就可以了 设置好了git的安装路径的可运行文件 ...