【axios】axios的基本使用

一、 Axios简介

1、 Axios是什么?

Axios是一个基于promise的HTTP库,类似于jQuery的ajax,用于http请求。可以应用于浏览器端和node.js,既可以用于客户端,也可以用于node.js编写的服务端。

2.、Axios特性

支持PromiseAPI

拦截请求与响应,比如:在请求前添加授权和响应前做一些事情。

转换请求数据和响应数据,比如:进行请求加密或者响应数据加密。

取消请求

自动转换JSON数据

客户端支持防御XSRF

二、安装使用

1、axios组件下载

npm install axios

2、引入axios

import axios from 'axios';

3、Axios常用得请求方法

get:一般用户获取数据

post:一般用于表单提交与文件上传

patch:更新数据(只将修改得数据推送到后端)

put:更新数据(所有数据推送到服务器)

delete:删除数据

备注:post一般用于新建数据,put一般用于更新数据,patch一般用于数据量较大的时候的数据更新。

4、Axios使用

4.1. GET传递参数 (get : 查询数据)

//第一种方式
axios.get('/query?name=tom')
.then(function (response) {
    console.log(response);
})

//第二种方式
axios.get('/query', {
    params: {
        name: 'tom'
    }
}).then(function (response) {
    console.log(response);
})

//第三种方式
axios({
  method: 'get',
  url: '/query',
  data: {
    name: 'tom',
  }
}).then(function (response) {
    console.log(response);
})

//第四种方式
axios.get('/adata/123')
.then (ret => {
console. log(ret. data)
})

4.2.POST传递参数 (post : 添加数据)

通过选项传递参数(默认传递的是json格式的数据)

axios.post('/query', {
    name: 'tom',
    icon: 'img_path'
}).then(function (response) {
    console.log(response);
})

4.3. DELETE传递参数 (delete :删除数据)

● 参数传递方式与GET类似

//第一种方式
axios.delete ( "/adata?id=123')
.then (ret=> {
    console. log (ret. data )
})

//第二种方式
axios. delete ('/adata/123 '
.then (ret= => {
console. log(ret. data)
})

//第三种方式
axios. delete ('/adata ', {
    params :{
        id: 123
    }
    })
.then (ret= => {
    console. log(ret. data)
})

//第四种方式
axios({
  method: 'delete',
  url: '/query',
  data: {
    name: 'tom',
  }
}).then(function (response) {
    console.log(response);
})

4. 4PUT传递参数 (put : 修改数据)

● 参数传递方式与POST类似

axios.put('/adata/123' , {
  uname:'tom',
  pwd: 123
}) .then (ret= => {
console. log(ret. data )
})

5.axios的响应结果

响应结果的主要属性

● data :实际响应回来的数据
● headers :响应头信息
● status :响应状态码
● statusText :响应状态信息

响应结果

axios.post ('/add').then (ret=> {
 console.log (ret)
})

6.axios的全局配置

● axios.defaults.timeout = 3000; // 超时时间

● axios.defaults.baseURL = 'http://localhost:3000/app'; // 默认地址

● axios.defaults.headers[ ' mytoken' ]='aqwerwqwerqwer2ewrwe23eresdf23' // 设置请求头

代码分析

//配置请求的基准URL地址
 axios.defaults.baseURL = 'http://127.0.0.1:3000/'
 //配置请求头信息
 axios.defaults.headers['mytoken'] = 'hello';
 axios.get('http://localhost:3000/axios-json').then(function(ret) {
            console.log(ret.data.uname)
        })

7.axios拦截器

1.请求拦截器

在请求发出之前设置一些信息

/ /添加一一个请求拦截器
axios.interceptors.request.use (funct ion (config) {
/ /在请求发出之前进行些信息设置
return config;
}, function (err) {
//处理响应的错误信息
}) ;

请求拦截器 代码分析

 //axios请求拦截器
        axios.interceptors.request.use(function(config){
        	console.log(config.url)
        	config.headers.mytoken = 'nihao'
        	return config
        },function(err){
        	console.log(err)
        })
//.then   返回服务器响应的数据

        axios.get('http://127.0.0.1:3000/adata').then(function(data){
        	console.log(data)
        })

2.响应拦截器

在获取数据之前对数据做一些加工处理

响应拦截器 代码分析

//axios响应式拦截器
        axios.interceptors.response.use(function(res) {
            // console.log(res)
            var data = res.data;
            return data;
        }, function(err) {
            console.log(err) //hello axios
        })
        axios.get('http://127.0.0.1:3000/adata').then(function(data) {
            console.log(data)
        })

8.一般开发会对axios二次封装进行使用(开发常用重点)

1,先创建一个文件夹

2.完整封装的request.js

import axios from 'axios'
import router from '@/router'

//创建一个新的axios对象
const request = axios.create({
    baseURL: process.env.VUE_APP_BASEURL, //后端接口地址统一前缀
    timeout: 30000
})

//request 拦截器
//在请求发送前对请求做一些处理,比如统一加token,对请求参数统一加密
request.interceptors.request.use(config => {
    console.log('process::',process)
    console.log('process.env::',process.env)
    console.log('baseURL::',process.env.VUE_APP_BASEURL)
    config.headers['Content-Type'] = 'application/json;charset=utf-8';  //设置参数请求类型
    let user = JSON.parse(localStorage.getItem("honey-user") || '{}')
    config.headers['token'] = user.token  //设置请求头

    return config
}, error => {
    console.error('request error: ' + error) // for debug
    return Promise.reject(error)
});

//response 拦截器
//可以在接口响应后统一处理结果
request.interceptors.response.use(response => { 
    let res = response.data;
    // 兼容服务端返回的字符串数据
    if (typeof res === 'string') {
        res = res ? JSON.parse(res) : res
    }
    //后端code返回401的时候去登录页面
    if (res.code === '401') {
        router.push('/login');
    }
    return res;
    },
    error => {
        console.error('response error: ' + error) // for debug
        return Promise.reject(error)
    }
)

export default request

3.分别创建两个文件,分别作为开发和生产的接口前缀路径

.env.development 开发地址

VUE_APP_BASEURL='http://localhost:9090'

.env.production 生产地址

VUE_APP_BASEURL='http://121.4.123.248/:9090'

4.main.js( request和baseUrl全局使用)

将封装的request和baseUrl对象挂载到vue的实例对象上面

Vue.prototype.$request=request

Vue.prototype.$baseUrl=process.env.VUE_APP_BASEURL

这样在全局都可以使用这两个对象了request和baseUrl

5.直接使用

首先介绍一下localStroage()的使用方法。

存值:localStroage.setItem("key","value")

取值:localStroage.getItem("key")

本地登录就是:

http://localhost:9090/login

服务器登录

http://121.4.123.248:9090/login

6.补充说明关于vue .env文件配置使用

https://blog.csdn.net/qq_41538097/article/details/117355115
相关推荐
Joeysoda1 小时前
Java数据结构 (从0构建链表(LinkedList))
java·linux·开发语言·数据结构·windows·链表·1024程序员节
清风-云烟2 天前
使用redis-cli命令实现redis crud操作
java·linux·数据库·redis·spring·缓存·1024程序员节
Joeysoda2 天前
Java数据结构 (链表反转(LinkedList----Leetcode206))
java·linux·开发语言·数据结构·链表·1024程序员节
比特在路上2 天前
StackOrQueueOJ3:用栈实现队列
c语言·开发语言·数据结构·1024程序员节
0xCC说逆向4 天前
Windows图形界面(GUI)-QT-C/C++ - Qt键盘与鼠标事件处理详解
c语言·开发语言·c++·windows·qt·win32·1024程序员节
明明真系叻5 天前
2025.1.18机器学习笔记:PINN文献精读
人工智能·笔记·深度学习·机器学习·1024程序员节
0xCC说逆向6 天前
Windows图形界面(GUI)-QT-C/C++ - Qt List Widget详解与应用
c语言·开发语言·c++·windows·qt·win32·1024程序员节
明明真系叻8 天前
2025.1.12机器学习笔记:GAN文献阅读
人工智能·笔记·深度学习·机器学习·1024程序员节
比特在路上9 天前
OJ12:160. 相交链表
c语言·数据结构·算法·链表·1024程序员节
earthzhang202110 天前
《深入浅出HTTPS》读书笔记(28):DSA数字签名
开发语言·网络协议·算法·https·1024程序员节