vue中使用axios发送请求

这篇博客详细介绍了Axios库的使用,包括基本的API请求、Promise的使用,以及如何结合async/await进行异步操作。通过实例展示了axios发起GET和POST请求的方式,并利用解构赋值简化了代码。同时,讲解了如何通过axios.get()和axios.post()简化请求过程。
摘要由CSDN通过智能技术生成

1.什么是axios?

Axios,是一个基于 promise 的网络请求库,作用于node.js和浏览器中,它是 isomorphic 的(即同一套代码可以运行在浏览器和node.js中)。

使用方式如下: 

<script>
        //调用axios方法得到的返回值是 promise 对象
        axios({
            //请求方式
            method: 'get',
            // 请求地址
            url: 'http://www.liulongbin.top:3006/api/getbooks'//黑马的老师提供的地址
        }).then(function(books) {
            console.log(books.data)
        })

        // 另一种写法
        const result = axios({
            method: 'get',
            url: 'http://www.liulongbin.top:3006/api/getbooks'
        })
        result.then(function(books){
            console.log(books.data)
        })
    </script>

2.axios请求图例

 3.使用 async 和 await 配合 axios 发起请求

    async和await必须结合使用,有await必须要使用async, 有async不一定要使用await,await是将异步转为同步,async 和 await 是 es7语法

 <script src="../lib/axios/axios.js"></script>
    <button id="app">post请求</button>
    <script>
        document.querySelector("#app").addEventListener("click", async function() {
            // 如果调用某个方法
            // await 只能在被 async 修饰的方法中使用
            const result = await axios({
                method: 'post',
                url: 'http://www.liulongbin.top:3006/api/post',
                data: {
                    name: 'zs',
                    age: 20
                }
            })
            console.log(result)
        })
    </script>

4.使用解构赋值

1.解构赋值的时候,使用 : 进行重命名

2.调用 axios 之后,使用 async / await 进行简化

3.使用解构赋值,从 axios 封装的大对象中, 把 data 属性解构出来 { data }

4.为了后期方便,把解构出来的 data 属性,使用冒号 : 进行重命名 ,一般重命名为 { data: res }

5.代码演示:

<script>
        document.querySelector("#app").addEventListener("click", async function() {
            const {
                //使用 :进行重命名
                data: res
            } = await axios({
                method: 'post',
                url: 'http://www.liulongbin.top:3006/api/post',
                data: {
                    name: 'zs',
                    age: 20
                }
            })
            console.log(res)
            //也可以单独取值
            console.log(res.message)
        })
    </script>

 

5.使用 axios.get() 、axios.post() 来简化请求过程

代码如下:

 //axios.post('url地址',{post请求数据体})
        document.querySelector("#app1").addEventListener("click", async function() {
            const {data: res} = await axios.post('http://www.liulongbin.top:3006/api/post', {
                name: 'zs',
                gender: '女'
            })
            console.log(res)

        });
        
        //axios.get('url地址',{
        //     get参数
        //     params: {}
        // })
        document.querySelector("#app2").addEventListener('click', async function() {
            const {data: res} = await axios.get('http://www.liulongbin.top:3006/api/getbooks', {
                params: {
                    id: 1
                }
            })
            console.log(res)
        })

测试结果如下:

 感谢浏览!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

John Rivers

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

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

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

打赏作者

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

抵扣说明:

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

余额充值