VUE 开发——AJAX学习(一)

一、AJAX入门和axios使用

1.AJAX定义:

异步的javascript和XML,就是使用XMLHttp Request对象与服务器通信,浏览器和服务器进行数据交换的技术。

2.使用axios

  1. 引入axios.js:https://unpkg.com/axios/dist/axios.min.js
  2. 使用axios函数
html 复制代码
<body>
    <p class="my-p"></p>
    <!-- 
        1.引入axios库
    -->
    <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
    <script>
        //2.使用axios函数
        axios({
            url: 'http://hmajax.itheima.net/api/province'
        }).then(result => {
            console.log(result)
            //控制台拿到result的省份对象
            console.log(result.data.list)
            //拼接数组元素
            console.log(result.data.list.join('<br>'))
            //把准备好的省份列表插入到页面
            document.querySelector('.my-p').innerHTML = result.data.list.join('<br>')
        })
    </script>
</body>

效果展示:

二、认识URL

1.定义:统一资源定位符,简称网址,用于访问网络上的资源

2.组成:协议、域名、资源路径

URL:协议://域名/资源路径

http://hmajax.itheima.net/api/province

  1. 协议:http

2.域名:hmajax.itheima.net

域名:标记服务器在互联网中的方位,必须添加

3.资源路径:/api/province

3.URL查询参数:浏览器提供给服务器的额外信息,让服务器返回浏览器想要的数据

语法:http://xxxx.com/xxx/xxx?参数名1=值1\&参数名2=值2

axios查询参数

使用params选项。携带参数名和值

html 复制代码
 axios({
            url: 'http://hmajax.itheima.net/api/city',
            //查询参数格式
            params:{
                pname:'河南省'
            }
        }).then(result => {
            console.log(result)
        }
})

三、常用请求方法和数据提交

请求方法:对服务器资源,要执行的操作

|--------|----------|
| 请求方法 | 操作 |
| get | 获取数据 |
| post | 提交数据 |
| put | 修改数据(全部) |
| delete | 删除数据 |
| patch | 修改数据(部分) |

axios请求配置:

url:请求的url网址

method:请求的方法,get可以省略(不区分大小写)

data:提交数据

html 复制代码
<body>
    <button class="btn">注册用户</button>
    <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
    <script>
        document.querySelector('.btn').addEventListener(
            'click',() => {
                axios({
                    url: 'http://hmajax.itheima.net/api/register',
                    //指定请求方法
                    method: 'post',
                    //提交数据
                    data: {
                        username: 'user',
                        password: '123'
                    }
                }).then(result => {
                    console.log(result)
                })

            }

        )
        
    </script>
</body>

四、axios错误处理

语法:在then方法后面,通过点语法调用catch方法,传入回调函数并定义形参

html 复制代码
axios({
                    url: 'http://hmajax.itheima.net/api/register',
                    //指定请求方法
                    method: 'post',
                    //提交数据
                    data: {
                        username: 'user',
                        password: '123'
                    }
                }).then(result => {
                    console.log(result)
                }).catch(error => {
                    //处理错误信息
                    console.log(error)
                    //具体错误原因
                    console.log(error.response.data.message)
                    alert(error.response.data.message)
                })

五、HTTP协议

1.请求报文:浏览器按照HTTP协议要求的格式,发送给服务器的内容,可以在网络中查看。

请求报文------错误排查

2.响应报文:规定了浏览器发送以及服务器返回内容的格式

HTTP响应状态码:用来表明请求是否成功完成

404:服务器找不到资源

|-----|-------|
| 状态码 | 说明 |
| 1XX | 信息 |
| 2XX | 成功 |
| 3XX | 重定向信息 |
| 4XX | 客户端错误 |
| 5XX | 服务端错误 |

六、接口文档

接口文档:由后端提供的描述接口的文章

接口:使用AJAX和服务器通讯时,使用的URL,请求方法,以及参数

七、form-serialize使用

form-serialize插件:快速收集表单元素的值

复制代码
 document.querySelector('.btn').addEventListener('click',() => {
            /*
                参数1:要获取哪个表单的数据
                参数2:配置对象
                hash 设置获取数据结构 ------true:JS对象(推荐,一般请求体里提交给服务器) ;                    false:查询字符串
                empty 设置是否获取空值
            */

            const form = document.querySelector('.example-form')
            const data = serialize(form,{ hash: true,empty: true})

        })
相关推荐
行者全栈架构师13 小时前
UniApp集成vk-uview-ui组件库详解:打造高效UI开发体验
前端·vue.js
Csvn15 小时前
Vue 3 defineModel 翻车实录:多个 v-model 绑定到底怎么写?
前端·vue.js
Momo__17 小时前
VueUse createReusableTemplate —— 单文件组件内的模板复用神器
前端·vue.js
程序员小富17 小时前
我开源了一个开发者专属的智能 JSON 工具,得到了媳妇高度认可
前端·vue.js·后端
JustHappy18 小时前
「软件设计思想杂谈🤔」“切图仔”也能懂编译原理?框架源码也许没那么难。聊聊 Vue 的编译(上)
前端·javascript·vue.js
假如让我当三天老蒯2 天前
Options API(选项式 API) 和 Composition API(组合式 API)
前端·vue.js·面试
秃头网友小李5 天前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
徐小夕5 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆5 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick5 天前
自动对焦学习-3
人工智能·学习·计算机视觉