axios在vue中的使用

文章目录


一、axios是什么?

Axios 是一个基于 promise 网络请求库,作用于node.js 和浏览器中。 它是 isomorphic 的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生 node.js http 模块, 而在客户端 (浏览端) 则使用 XMLHttpRequests。

二、使用步骤

2.1 下载

powershell 复制代码
npm install  axios -S

2.2 引入

powershell 复制代码
import axios from 'axios'

2.3 使用

Get请求

js 复制代码
import axios from 'axios'
// 向给定ID的用户发起请求
axios.get('/user?ID=12345')
  .then(function (response) {
    // 处理成功情况
    console.log(response);
  })
  .catch(function (error) {
    // 处理错误情况
    console.log(error);
  })
  .finally(function () {
    // 总是会执行
  });

// 上述请求也可以按以下方式完成(可选)
axios.get('/user', {
    params: {
      ID: 12345
    }
  })
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  })
  .finally(function () {
    // 总是会执行
  });  

// 支持async/await用法
async function getUser() {
  try {
    const response = await axios.get('/user?ID=12345');
    console.log(response);
  } catch (error) {
    console.error(error);
  }
}

Post请求

发起一POST请求

js 复制代码
axios.post('/user',{
	firstName:'Fred',
	lastName:'Flintstone'
}).then(function(response){
	console.log(response);
}).catch(function(error)){
	console.log(error);
}

发起多个并发请求

javascript 复制代码
function getUserAccount() {
  return axios.get('/user/12345');
}

function getUserPermissions() {
  return axios.get('/user/12345/permissions');
}

const [acct, perm] = await Promise.all([getUserAccount(), getUserPermissions()]);

// OR

Promise.all([getUserAccount(), getUserPermissions()])
  .then(function ([acct, perm]) {
    // ...
  });

将HTML Form 转换JSON进行请求

javascript 复制代码
const {data} = await axios.post('/user', document.querySelector('#my-form'), {
  headers: {
    'Content-Type': 'application/json'
  }
})

Forms

Multipart (multipart/form-data)

javascript 复制代码
const {data} = await axios.post('https://httpbin.org/post', {
    firstName: 'Fred',
    lastName: 'Flintstone',
    orders: [1, 2, 3],
    photo: document.querySelector('#fileInput').files
  }, {
    headers: {
      'Content-Type': 'multipart/form-data'
    }
  }
)

URL encoded form (application/x-www-form-urlencoded)

javascript 复制代码
const {data} = await axios.post('https://httpbin.org/post', {
    firstName: 'Fred',
    lastName: 'Flintstone',
    orders: [1, 2, 3]
  }, {
    headers: {
      'Content-Type': 'application/x-www-form-urlencoded'
    }
})

三、封装

在src下创建utils目录,在该目录下创建文件 request.js

javascript 复制代码
import axios from "axios";
import router from '../router/index'
// 1、创建axios对象
const service = axios.create({
	baseURL: 'http://localhost:9090/drsm',
});
//2、请求拦截器 
service.interceptors.request.use(config => {
	//在headers中加入认证信息。
	// if(token){
	//        config.headers['Token'] = token
	//    }
	return config
}, error => {
	Promise.reject(error);
})

//响应拦截器
service.interceptors.response.use(
	(response) => {
		//console.log(response);
		const {
			data
		} = response;
		if (data.code === 200 || data.code === 201) {
			//回传的数据
			return data;
		} else {
			return Promise.reject(new Error(data.message))
		}
	},
	error => {
		let msg;
		//console.log(error);
		if (error.response) {
			switch (error.response.status) {
				case 500:
					msg = "500-服务器发生错误,请及时联系管理员"
					break;
				case 404:
					msg = "404-你访问的页面不存在"
					break;
				case 401:
					msg = "401-请先登录系统,再完成操作"
					break;
				case 403:
					msg = "403-额...没有权限访问"
					break
				default:
					msg = "555-发生错误,请及时联系管理员"
					break;
			}
			//登录界面发生错误时不跳转到错误页,
			if(error.config.url=='/login'){
				return Promise.reject(new Error(msg))
			}
			router.push({
				path: '/error',
				query: {
					msg: msg
				}
			});
		} else {
			msg = "连接不到目标服务器"
		}

		return Promise.reject(new Error(msg))
	}
)

export default service;

在utils下创建api目录,接着创建文件 course.js

js 复制代码
import qs from 'qs'
import service from '@/utils/request'


export function loginReq(name, pwd) {
	const data = {
		username: name,
		password: pwd
	};
	return service.post('/login',qs.stringify(data));
}


export function addUserReq(user){
	return service.post('/addUser',qs.stringify(user));
}

export function userExist(username){
	let url = '/userExist/'+username;
	return service.get(url);
}
相关推荐
飞的肖3 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案110 分钟前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_7482548815 分钟前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.27 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营31 分钟前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端1 小时前
0基础学前端-----CSS DAY9
前端·css
joan_851 小时前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
还是大剑师兰特1 小时前
什么是尾调用,使用尾调用有什么好处?
javascript·大剑师·尾调用
m0_748236112 小时前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust