当前位置: 首页 > article >正文

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函数
  3. <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选项。携带参数名和值

 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:提交数据 

<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方法,传入回调函数并定义形参 

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})

        })

 


http://www.kler.cn/news/326561.html

相关文章:

  • 群晖安装Audiobookshelf(有声书)
  • YOLOv11改进 | Neck篇 | YOLOv11引入BiFPN双向特征金字塔网络
  • 项目管理专业资质认证ICB 3中关于项目经理素质的标准
  • FreeRTOS调度器与任务
  • HTML初认识 -- 第二课(全网最好的入门课)
  • el-cascader懒加载回显问题
  • 这 5 个自动化运维场景,可能用 Python 更香?
  • 【工程测试技术】第3章 测试装置的基本特性,静态特性和动态特性,一阶二阶系统的特性,负载效应,抗干扰性
  • Python知识点:如何使用Flink与Python进行实时数据处理
  • Docker快速搭建PostgreSQL15流复制集群
  • 端模一体,猎豹移动对大模型机器人发展路径清晰
  • 每天认识几个maven依赖(ant)
  • dea插件开发-自定义语言9-Rename Refactoring
  • 【以图搜图代码实现2】--faiss工具实现犬类以图搜图
  • mips指令系统简介
  • AI大模型面试大纲
  • 基于单片机的催眠电路控制系统
  • [云服务器15] 全网最全!手把手搭建discourse论坛,100%完成
  • 什么是 Apache Ingress
  • 钉钉H5微应用Springboot+Vue开发分享
  • win11下 keil报错Cannot load driver ‘D:\Keil_v5\ARM\Segger\JL2CM3.dll‘
  • WAF,全称Web Application Firewall,好用WAF推荐
  • 小巧机身,但强劲动力实现千元级净须,未野迷你剃须刀测评
  • Java 编码系列:反射详解与面试题解析
  • Julia的安装和使用(附vscode中使用)
  • WordPress 要求插件开发人员进行双因素身份验证
  • Python3 爬虫教程 - Web 网页基础
  • 前端工程规范-3:CSS规范(Stylelint)
  • 栈的最小值
  • 17、CPU缓存架构详解高性能内存队列Disruptor实战