Ajax笔记

介绍

        Ajax是一种网页开发技术,全称是Asynchronous JavaScript and XML(异步JavaScript和XML)。作用如下:

  • 数据交换:可以通过Ajax给服务器发送请求,并获取服务器响应的数据。即前端动态的发送Ajax到服务器端来获取相应数据,接收到数据后基于vue中的指令完成相应的数据渲染。
  • 异步交互:能够在不中断用户操作(不重新加载整个页面)的情况下与服务器交换数据并更新部分网页。这意味着用户在提交请求后,仍然可以继续浏览或操作页面,直到服务器响应返回。

与异步交互相对:同步交互

        同步交互:访问客户端——请求服务器——服务器处理(客服端等待)——服务器响应(客服端加载)——客户端继续访问

        我们访问链接,加载图片、视频都属于同步交互,而异步交互则可在不中断客服端操作的情况下与服务器交换数据

原生Ajax

一、创建XMLHttpRequest对象,用于和服务器交换数据

var xhr = new XMLHttpRequest();//创建XMLHttpRequest对象

二、调用 XMLHttpRequest 对象中的 open() 方法来设置请求的方式和请求路径,并调用 send() 方法来向服务器发送请求

xhr.open(method, url, async);//发送异步请求
xhr.send(data);//发送请求
  • method: 请求类型,如 “GET”, “POST”, “PUT”, “DELETE” 等。
  • url: 请求的URL(此处使用本地文本代替)。
  • async: (可选) 布尔值,表示请求是否异步,默认为true。
  • data: (可选) 发送到服务器的数据,通常为json数据

三、获取服务器响应的数据

<script>
    function loadDoc() {
        var my_xml = new XMLHttpRequest();//创建XMLHttpRequest对象,它是实现Ajax通信的核心。
        my_xml.onreadystatechange = function () {//为XML对象设置了一个事件处理器,用于监听readyState属性的变化。
            if (this.readyState == 4 && this.status == 200) {
                document.getElementById("demo").innerHTML = this.responseText;
            }
        };
        my_xml.open("GET", "ajax_info.txt", true);
        my_xml.send();
    } 
</script>

        onreadystatechange 是 my_xml 的一个标准事件处理器属性,用来监听 readyState 和 status 的属性变化,两属性不同的值代表不同的含义:

readyState

0:请求未初始化

1:服务器连接已建立

2:请求已收到

3:正在处理请求

4:请求已完成且响应已就绪

status

200: "OK"

403: "Forbidden"

404: "Not Found"

        当readyState变为4(请求已完成)并且HTTP状态码为200(请求成功)时,函数将进行:

  1. 使用document.getElementById("demo")获取页面中ID为demo的元素。
  2. 将该元素的innerHTML属性设置为this.responseText,即服务器返回的响应文本。
<!DOCTYPE html>//示例
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>AAA专业苏打饼干打孔</title>
</head>

<body>
    <input type="button" value="获取数据" onclick="loadDoc()">
    <div id="demo"></div>
</body>
<script>
    function loadDoc() {
        var my_xml = new XMLHttpRequest();
        my_xml.onreadystatechange = function () {
            if (this.readyState == 4 && this.status == 200) {
                document.getElementById("demo").innerHTML = this.responseText;
            }
        };
        my_xml.open("GET", "../json/students_info.json", true);
        my_xml.send();
    } 
</script>

</html>

        但这种方式比较繁琐,且在早期的浏览器中可能还会遇到兼容问题,所以原生Ajax已不再使用,现在所使用的是基于原生Ajax封装起来的技术如Axios

Axios 

一、自备Axios文件并引入,或直接引入官方文档

<script src="js/axios-0.18.0.js"></script>
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>

二、使用Axios发送请求,并获取响应结果

    axios({
        method: "get",//请求方式为get
        url: 'http://example.com/api/cookies'//此处url仅做示范
        //请求的路径,如需传递数据则在url后以?key=value,例:?name=123&age=123的形式传输数据
    }).then((result) => {//.then响应服务器数据并调用"成功回调函数"
        console.log(result.data); //拿到result中的data属性
    });
    axios({
        method: "post",//post传输数据在请求体中传输,通过data属性来指定所传请求参数
        url: 'http://example.com/api/cookies/${cookieId}',
        data: "id=1"
    }).then((result) => {
        console.log('数据删除成功:', result.data);
    });

例: 

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>AAA专业苏打饼干打孔</title>
    <script src="../js/axios-0.18.0.js"></script>
</head>
 
<body><input type="button" value="获取数据" onclick="get()">
    <input type="button" value="删除数据" onclick="post()">
</body>
<script>
    function get() {
        //通过axios发送异步请求-get
        axios({
            method: "get",
            url: 'https://yapi.pro/mock/557466/user/getById'
        }).then((result) => {
            console.log(result.data);
        });
    }
 
    function del() {
        //通过axios发送异步请求-post
        axios({
            method: "post",
            url: 'https://yapi.pro/mock/557466/user/getById',
            data: "id=1"
        }).then((result) => {
            console.log('数据删除成功:', result.data);
        });
    }
</script>
 
</html>

        但这种请求方式 过于复杂,为方便书写,Axios已经为支持的所有请求方式提供了请求方式的别名:

  • axios.get(url, [config]):
    • url: 必需,字符串,请求的服务器URL。
    • config: 可选,配置对象,可以包含以下选项:
      • params: 将被添加到URL查询字符串中的参数。
      • headers: 请求头信息。
      • responseType: 响应数据的类型,例如 ‘json’, ‘blob’, ‘document’, ‘arraybuffer’, ‘text’, ‘stream’。
      • timeout: 请求超时的毫秒数。
      • withCredentials: 是否跨站点请求时携带凭证(cookies)。
  • axios.delete(url, [config]):
    • url: 必需,字符串,请求的服务器URL。
    • config: 可选,配置对象,与 axios.get 的配置选项类似,可以包含 params, headers, timeout, withCredentials 等属性。
  • axios.post(url, [data], [config]):
    • url: 必需,字符串,请求的服务器URL。data: 可选,要作为请求体发送的数据,可以是对象、字符串或数组。
    • config: 可选,配置对象,与 axios.get 的配置选项类似,但还可以包含 data 的处理选项,如 transformRequest 和 transformResponse。
  • axios.put(url, [data], [config]):
    • url: 必需,字符串,请求的服务器URL。
    • data: 可选,要作为请求体发送的数据,通常用于更新资源。
    • config: 可选,配置对象,与 axios.post 的配置选项相同。

        简化后:

<script>
    function get() {
        //通过axios发送异步请求-get
        axios.get('http://example.com/api/cookies').then((result) => {
            console.log(result.data);
        });
    }
    function del() {
        //通过axios发送异步请求-post
        axios.post('http://example.com/api/cookies', id = 1).then((result) => {
            console.log('数据删除成功:', result.data);
        }); 
    }
</script>
  •         接下来我们将其与vue放在一起使用,我们需要浏览器页面加载完成后自动发送异步请求到服务端获取数据,并自动将其渲染在页面中。想实现这一点离不开vue。
    •         前面介绍过vue有生命周期,其中有八个钩子函数,我们需要在 mounted 钩子函数中发送异步请求。
    • <!DOCTYPE html>
      <html lang="en">
      
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>AAA专业苏打饼干打孔</title>
          <script src="../js/axios-0.18.0.js"></script>
          <script src="../js/vue.js"></script>
      </head>
      
      <body>
          <div id="app">
              <table border="1" cellspacing="0" width=60%>
                  <tr>
                      <th>编号</th>
                      <th>姓名</th>
                      <th>年龄</th>
                      <th>性别</th>
                      <th>编号</th>
                  </tr>
                  <tr align="center" v-for="(person, index) in emps" :key="index">
                      <td>{{ index+1}}</td>
                      <td>{{ person.name }}</td>
                      <td>{{ person.age }}</td>
                      <td v-if="person.gender==1">{{ "男" }}</td>
                      <td v-else-if="person.gender==2">{{ "女" }}</td>
                      <td>{{ person.studentID }}</td>
                  </tr>
              </table>
          </div>
      </body>
      <script>
          new Vue({
              el: "#app",
              data: {
                  emps: [],
              },
              mounted() {//发送异步请求,访问数据
                  axios.get("https://yapi.pro/mock/557466/user/list").then(result => {
                      this.emps = result.data.students;
                  })
              },
          })
      </script>
      
      </html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/900238.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

秦时明月2搭建笔记

1.具体配置 数据库不修改&#xff0c;如果修改了&#xff0c;gm那边也要 2.数据库 3.上传配置文件出现问题 参考&#xff1a;对于测试时&#xff0c;错误信息 Caused by: com.mysql.jdbc.PacketTooBigException: Packet for query is too large-CSDN博客 4.启动tomcat&#x…

指增和中性产品的申赎加减仓及资金调拨自动化伪代码思路

定义一些关键字代表的意义 STRUCT: 代表需要输入的格式化的信息IMPORT: 代表需要输入的外部信息&#xff0c; 这些信息通常是客观的SEARCH: 需要从某地比如数据库检索搜集信息SUM: 一种宏观的加和操作&#xff0c; 比如两个股票户ABAB&#xff0c;微观上实际还是有差异GROUP: …

Umi UI报错:连接失败,请尝试重启dev服务

Umi UI连接失败&#xff0c;请尝试重启dev服务 使用umi ui时遇到以下问题 报错如下 从报错可以看出是淘宝镜像失效的问题&#xff0c;检查淘宝镜像 可以看出淘宝镜像是最新的&#xff0c;并无问题 经过查找发现报错是因为依赖文件中使用了旧的淘宝镜像&#xff0c;在node…

【SAP Hana】X-DOC:数据仓库ETL如何抽取SAP中的CDS视图数据

【SAP Hana】X-DOC&#xff1a;数据仓库ETL如何抽取SAP中的CDS视图数据 1、无参CDS对应数据库视图2、有参CDS对应数据库表函数3、封装有参CDS为无参CDS&#xff0c;从而对应数据库视图 1、无参CDS对应数据库视图 select * from ZFCML_REP_V where mandt 300;2、有参CDS对应数…

开发涉及的安全规范整理

#1024程序员节&#xff5c;征文# 文章目录 前言安全场景与措施API调用方式鉴权参数校验日志打印数据保存加密 总结 前言 这篇文章我们来整理下写代码和方案设计中的安全规范问题&#xff0c;内容偏服务端&#xff0c;即使是入门的新人&#xff0c;如果你对安全有所了解会让成熟…

go语言中的Scanf()输入函数

Scanf() 第一种情况 package mainimport "fmt"func main() {var a intfor {fmt.Println("请输入一个整数:")fmt.Scanf("%d", &a)fmt.Println("----------------", a)} }运行结果&#xff1a; 解释&#xff1a; 出现这种现象是因…

CentOS 8在Linux虚拟机修改IP地址,出现:错误:“ens160“ 不是活动的连接。错误:未提供活动连接。

问题&#xff1a;错误&#xff1a;"ens160" 不是活动的连接。错误&#xff1a;未提供活动连接。 1.查看网络服务运行状态&#xff1a; 1)CentOS 7执行命令&#xff1a;systemctl status network 2)CentOS 8执行命令&#xff1a;systemctl status NetworkManager&a…

双十一有哪些适合学生党的好物?五款学生党必备好物分享

在双十一这个全民狂欢的购物盛宴中&#xff0c;不仅仅是寻找生活的小确幸&#xff0c;更是自我提升与投资的最佳时机。学习&#xff0c;作为个人成长的阶梯&#xff0c;其相关的好物选择显得尤为重要。本文精选了一系列学习、生活神器&#xff0c;旨在为您的学习之旅增添动力与…

手机防窥膜的工作原理是怎样的?有必要使用防窥膜吗?

在信息高度发达的社会中&#xff0c;我们通过手机可以实现非常多的操作&#xff0c;同时手机中有存在许多我们的隐私信息&#xff0c;伴随使用手机的时间增多&#xff0c;手机中的信息也有可能被暴露&#xff0c;尤其是在公共场所旁人很容易通过瞥视你的手机屏幕获取到一些信息…

青少年编程能力等级测评CPA C++(三级)-试卷1

青少年编程能力等级测评CPA C&#xff08;三级&#xff09;-试卷1 一、单项选择题&#xff08;共15题&#xff0c;每题3分&#xff0c;共45分&#xff09; CP3_1_1&#xff0e;以下有关模拟算法的叙述中&#xff0c;不正确的是&#xff08; &#xff09;。 A&#xff0e;模拟…

普通数组矩阵

文章目录 普通数组一、最大子数组二、合并区间三、轮转数组四、除自身以外数组的乘积五、缺失的第一个正数 普通数组 一、最大子数组 题目链接 方法一&#xff1a;动态规划 方法二&#xff1a;前缀和&#xff08;有点难理解&#xff09; 二、合并区间 题目链接 三、轮…

软件部署-Docker容器化技术(二)

上一期分享了Docker的一些基本内容&#xff0c;这一期主要对构建基础镜像和Docker网络、文件挂载再展开分享下&#xff0c;可能不一定做得很好&#xff0c;主要是在学习的过程中有一些自己的总结和思考&#xff0c;和大家一起学习。 名词说明&#xff1a;这里的宿主机是指liun…

【D3.js in Action 3 精译_037】4.1 DIY 实战:D3 源码分析之——d3.timeFormat() 函数

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第一部分 D3.js 基础知识 第一章 D3.js 简介&#xff08;已完结&#xff09; 1.1 何为 D3.js&#xff1f;1.2 D3 生态系统——入门须知1.3 数据可视化最佳实践&#xff08;上&#xff09;1.3 数据可…

Shopee虾皮登录不了的常见原因及解决方式

在近年来&#xff0c;随着电子商务的迅猛发展&#xff0c;Shopee虾皮作为东南亚地区的领先购物平台&#xff0c;吸引了大量用户。一些用户在使用过程中常常遇到登录问题&#xff0c;而登录不了的原因可能多种多样&#xff0c;包括网络连接不稳定、账号信息输入错误&#xff0c;…

【搭建个人图库】Docker部署Piwigo图库与公网环境远程传图全攻略

文章目录 前言1. 安装Docker2. 创建并启动Piwigo容器3. 本地访问测试与简单使用4. 公网远程访问本地Piwigo4.1 内网穿透工具安装4.2 创建远程连接公网地址4.3 使用固定公网地址远程访问 前言 本文和大家分享一下如何在Linux系统使用Docker部署一款开源的网络图片库管理系统Piw…

54页可编辑PPT | 大型集团企业数据治理解决方案

这份PPT是关于大型集团企业数据治理的全面解决方案&#xff0c;它详细介绍了数据治理的背景、需求、管理范围、框架、解决思路&#xff0c;以及数据治理在实际操作中的关键步骤。内容涵盖了数据架构、数据质量、数据应用等方面的问题&#xff0c;并提出了数据资产透视、智能搜索…

K8S如何基于Istio重新实现微服务

K8S如何基于Istio重新实现微服务 认识 Istio前言Istio 的理念Istio 的架构数据平面控制平面服务与 Istio 的关系 Istio 实践环境准备安装 Helm安装Istio 使用 Istio 代理运行应用情感分析应用的架构使用 Istio 代理运行应用Sidecar 注入Ingress 网关网关资源VirtualService 资源…

离线部署jdk8,jdk17, jdk21

目录 一、下载地址二、环境三、离线部署思路步骤 四、部署脚本 在开发过程中&#xff0c;有时我们需要在同一台机器上安装多个不同版本的 JDK&#xff0c;以满足不同项目的需求。本文将详细介绍如何在 Ubuntu 24.04 中离线安装 JDK8、JDK17 和 JDK21。 一、下载地址 建议下载O…

融合DevOps打造企业高效流程体系的实践与探索

一、引言 转眼间&#xff0c;我已毕业十多年&#xff0c;在IT领域深耕不辍&#xff0c;曾涉足全栈研发、大数据研发、架构设计与项目管理等多个岗位&#xff0c;更主导过公司从市场到交付再到运营的全链条流程建设。在这漫长的职业生涯中&#xff0c;一个问题始终萦绕在我心头&…

web前端练习

01 代码&#xff1a;HTML部分 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>search</title>…