Ajax 笔记/练习

Ajax

异步JavaScript和XML

作用

实现 HTML 在不整体刷新的情况下,通过后台服务器,请求数据并局部更新页面内容

  • 操作流程

    image-20231019150656824

Ajax 使用

  • XMLHttpRequest

    通过new 关键字可以创建XMLHttpRequest() 对象。

    var req = new XMLHttpRequest();
    
    方法和属性说明
    req.open(method, url, async)method:[GET|POST] url:url async:[true(异步,默认) | false(同步)]
    req.send()发送HTTP 请求
    req.responseText获得字符串形式的响应数据。
    readyState存有XMLHttpRequest 的状态。 请求发送到后台后,状态会从0 到4 发生变化: 1:服务器连接已建立。 2:请求已接收。 3:请求处理中。 4:请求已完成,且响应已就绪。
    req.onreadystatechange每当readyState 属性改变时,就会调用该函数。
    status状态码

image-20231019150731887

  • 创建 Ajax 对象

    var xhr = new XMLHttpRequest()
    
  • onreadystatechange

    readyState 的值发生变化就会触发该事件

    xhr.onreadystatechange = function () {// 每次readyState 改变的时候触发该事件
    }
    
  • 配置连接信息

    Ajax 对象中的 .open 方法用来配置请求信息

    xhr.open("GET","aj.php",true);
    
    • 第一个参数是本次的请求方式 get / post / put / …
    • 第二个参数是本次请求的 url
    • 第三个参数是本次请求是否是异步,true (默认)表示异步,false 表示同步
    • xhr.open('get','/data.php')
  • 发送请求

    xhr.send()
    

Ajax 状态码

  • readyState

    readyState === 0 : 表示未初始化完成,也就是 open 方法还没有执行
    readyState === 1 : 表示配置信息已经完成,也就是执行完 open 之后
    readyState === 2 : 表示 send 方法已经执行完成
    readyState === 3 : 表示正在解析响应内容
    readyState === 4 : 表示响应内容已经解析完毕,可以在客户端使用了

    只有当 readyState === 4 的时候,我们才可以正常使用服务端给我们的数据,配合 http 状态码 status===200 两个条件都满足本次请求才可以完成

    如果XMLHttpRequest对象的readyState属性值等于4,表示异步调用过程完毕,就可以通过XMLHttpRequest对象的 responseText 属性或 responseXml 属性来获取数据

使用 Ajax 发送请求时携带的参数

  • 与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

    然而,在以下情况中,请使用 POST 请求:

    • 无法使用缓存文件(更新服务器上的文件或数据库)
    • 向服务器发送大量数据(POST 没有数据量限制)
    • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
  • get 请求的参数就直接在 url 后面进行拼接就可以

    const xhr = new XMLHttpRequest()
    // 直接在地址后面加一个 ?,然后以 key=value 的形式传递 // 两个数据之间以 & 分割
    xhr.open('get', './data.php?a=100&b=200')
    xhr.send()
    

    这样服务端就能接受到两个参数 一个是 a,值是 100,一个是 b,值是 200

  • post 请求的参数是携带在请求体 send() 中的,所以,不需要再 url 后面拼接

    const xhr = new XMLHttpRequest()
    xhr.open('post', './data.php')
    xhr.send('a=100&b=200')
    // 如果是用 ajax 对象发送 post 请求,必须要先设置一下请求头中的 content- type
    // 告诉一下服务端我给你的是一个什么样子的数据格式 xhr.setRequestHeader('content-type', 'application/x-www-form- urlencoded')
    

Ajax 封装使用实例

  • index.html 文件

    <!DOCTYPE html>
    <html>
    <head><meta charset="UTF-8">
    </head>
    <body><div>part_one</div><input type="button" value="点击局部刷新" onclick="part_refresh()"><div id="d1"></div>
    </body>
    <script>function part_refresh(){// 创建点击 button 触发刷新的方法var xhr = new XMLHttpRequest();// 创建 Ajax 对象xhr.onreadystatechange=function re(){// 当 readyState 的值发生变化时执行此方法中的代码	if(xhr.readyState===4 && xhr.status===200){// 当内容解析完毕,并且成功处理了请求时执行语句document.getElementById("d1").innerHTML=xhr.responseText;// 在网页上第二个 <div> 标签内输出获取的 xhr 对象文本格式的响应数据}}xhr.open("GET","aj.php",true);// 配置连接信息xhr.send();// 发送请求}
    </script>
    </html>
    
  • aj.php 文件

    <?php
    $str = "hello";
    echo $str;
    ?>
    
  • 将 index.html 文件和 aj.php 文件放入 PHPstudy 的 www 目录下

    开启 phpstudy

  • 在浏览器地址栏打开 127.0.0.1/index.html

    image-20231019150746449

    点击局部刷新按钮后

    可以看到第二个源代码 div 块中的值发生变化

    image-20231019150754987

局部刷新与整页刷新的区别

  • 整页刷新

    手动更改源代码中第一个 <div> 块中的文本内容

    image-20231019150811540

    点击整页刷新按钮,发现更改的内容恢复到更改前的状态

    image-20231019150902692

  • Ajax 局部刷新

    手动更改源代码中第一个 <div> 块中的文本内容

    image-20231019150947151

    点击局部刷新按钮,发现手动更改的内容未发生改变,而下方刷新出来了新的内容,源代码中手动更改的 <div> 块未改变,第二个 <div> 代码块刷新后发生改变

    image-20231019151002779

前端跨域问题

同源策略

协议+域名+端口"三者相同,即便两个不同的域名指向同一个ip地址,也非同源

同源策略限制以下几种行为:

  • Cookie、LocalStorage 和 IndexDB 无法读取
  • DOM和JS对象无法获得
  • AJAX 请求不能发送
URL说明是否允许通信
127.0.0.1/index.html
127.0.0.1/aj.php
同一域名,不同文件或路径允许
http://www.domain.com:8000/a.js
http://www.domain.com/b.js
同一域名,不同端口不允许
http://www.domain.com/a.js
https://www.domain.com/b.js
同一域名,不同协议不允许
http://www.domain.com/a.js
http://192.168.4.12/b.js
域名和域名对应相同ip不允许
http://www.domain.com/a.js
http://x.domain.com/b.js
http://domain.com/c.js
主域相同,子域不同不允许
http://www.domain1.com/a.js
http://www.domain2.com/b.js
不同域名不允许

Ajax 练习

同步请求

  • 环境:

    • ajax.html 放在 phpstudy 的 www 页面下
    • flag.php 放在 phpstudy 的 www 页面下
    • 浏览器访问 127.0.0.1/ajax.html
    • 开启 phpstudy
  • 效果:等待五秒同步刷新文本框和获取的 flag

  • ajax.html 代码

    <!DOCTYPE html>
    <html lang="zh">
    <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
    </head>
    <body><textarea name="" id="kuang" cols="30" rows="10"></textarea>
    </body>
    <script>var x=new XMLHttpRequest;// 创建 Ajax 对象x.open("GET","http://127.0.0.1/flag.php",false);// 配置连接信息x.send();// 发送请求var flag=x.responseText;// 创建变量 flag 接收数据console.log(flag);document.getElementById("kuang").value=flag;// 将文本框中的字符修改为获取的 flag
    </script>
    </html>
    
  • flag.php 代码

    <?php sleep(5); ?>
    ajax flag
    

    image-20231019170929894

异步请求

  • 环境:

    • ajax.html 放在 phpstudy 的 www 页面下
    • flag.php 放在 phpstudy 的 www 页面下
    • 浏览器访问 127.0.0.1/ajax.html
  • 效果:

    浏览网页立刻加载文本框,等待五秒后加载获取的 flag

    点击局部刷新按钮五秒后,flag 重新获取,而页面不刷新

    <!DOCTYPE html>
    <html lang="zh">
    <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
    </head>
    <body><textarea name="" id="kuang" cols="30" rows="10"></textarea><input type="button" value="局部刷新" onclick="flush()">
    </body>
    <script>function flush(){// 创建点击 button 触发刷新的方法var x=new XMLHttpRequest;// 创建 Ajax 对象x.open("GET","http://127.0.0.1/flag.php",true);// 配置连接信息x.send();// 发送请求x.onreadystatechange=function(){// 当 readyState 的值发生变化时执行此方法中的代码	var flag=x.responseText;// 创建变量 flag 接收数据console.log(flag);document.getElementById("kuang").value=flag;// 将文本框中的字符修改为获取的 flag}}flush()</script>
    </html>
    

    image-20231019172433622

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Rclone连接Onedrive

一、Rclone介绍 Rclone是一款的命令行工具&#xff0c;支持在不同对象存储、网盘间同步、上传、下载数据。 我们这里连接的onedrive&#xff0c;其他网盘请查看官方文档。 注意&#xff1a; 需要先在Windows下配置好了&#xff0c;然后再将rclone配置文件复制到Linux的rclone配…

【proteus】8086仿真、汇编语言

1.创建好新项目 2.点击source code 弹出VSM 3. 4.注意两个都不勾选 可以看到schematic有原理图出现 5. 再次点击source code 6.project/project settings&#xff0c;取消勾选embed 7. add 8.输入文件名保存后&#xff1a; 注意&#xff1a;proteus不用写dos的相关语句 。

【NPM】particles.vue3 + tsparticles 实现粒子效果

在 NPM 官网搜索这两个库并安装&#xff1a; npm install element-plus --save npm i tsparticles使用提供的 vue 案例和方法&#xff1a; <template><div><vue-particlesid"tsparticles":particlesInit"particlesInit":particlesLoaded&…

华为OD机试 - 代表团坐车 - 动态规划(Java 2023 B卷 200分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷&#…

Ubuntu 22.04 中安装 fcitx5

Ubuntu 22.04 中安装 fcitx5 可以按照以下步骤进行&#xff1a; 添加 fcitx5 的 PPA 首先&#xff0c;添加 fcitx5 的官方 PPA&#xff1a; sudo add-apt-repository ppa:fcitx-team/fcitx5更新软件包列表 sudo apt update安装 fcitx5 sudo apt install fcitx5 fcitx5-conf…

Mysql表结构差异比较

1、背景 我们在开发过程中&#xff0c;大部分情况下都是好几个版本一起并行&#xff0c;有时候如果某个版本表结构改动较大&#xff0c;但是忘记了记录DDL脚本&#xff0c;这个时候需要人工去把新增或修改的DDL脚本整理出来&#xff08;主要是为了解决 数据库新增字段&#xff…

高效表达三步

一、高效表达 高效表达定主题搭架子填素材 第一&#xff1a; 1个核心主题&#xff0c;让别人秒懂你的想法 &#xff08;表达要定主题&#xff09; 第二&#xff1a; 3种经典框架&#xff0c;帮你快速整理表达思路 第三&#xff1a; 2种表达素材&#xff0c;让发言更具说服力…

在 Python 中执行 Shell 命令并获取输出

在本文中&#xff0c;我们将学习如何借助 os.system() 从 Python 脚本执行 cmd 命令。 我们还将学习如何借助 Python 中的 subprocess 模块以更简单的方式从脚本执行 cmd 命令。 从 Python 脚本执行 CMD 命令并使用 os.system() 获取输出 我们出于不同目的在命令提示符或任何其…

可视化 | python可视化相关库梳理(自用)| pandas | Matplotlib | Seaborn | Pyecharts | Plotly

文章目录 &#x1f4da;Plotly&#x1f407;堆叠柱状图&#x1f407;环形图&#x1f407;散点图&#x1f407;漏斗图&#x1f407;桑基图&#x1f407;金字塔图&#x1f407;气泡图&#x1f407;面积图⭐️快速作图工具&#xff1a;plotly.express&#x1f407;树形图&#x1f…

正点原子嵌入式linux驱动开发——Linux中断

不管是单片机裸机实验还是Linux下的驱动实验&#xff0c;中断都是频繁使用的功能&#xff0c;在裸机中使用中断需要做一大堆的工作&#xff0c;比如配置寄存器&#xff0c;使能IRQ等等。但是Linux内核提供了完善的中断框架&#xff0c;只需要申请中断&#xff0c;然后注册中断处…

跟我一起写个虚拟机 .Net 7(四)- LC_3 解析实例

没想到这篇文章持续了这么久&#xff0c;越学越深&#xff0c;愣是又买了一本书《计算机系统概论》&#xff0c;当然&#xff0c;也看完了&#xff0c;受益匪浅。 系统化的学习才是正确的学习方式&#xff0c;我大学就没看到过这本书&#xff0c;如果早点看到&#xff0c;可能…

STM32F4之系统滴答定时器

一、系统滴答定时器概述 传统定时器&#xff1a;如手机闹钟&#xff0c;闹钟等就是一个简单地计数器。 定时器概念&#xff1a;由时钟源计数器计数值组成的计数单元。 系统嘀嗒定时器首先是存在于内核里&#xff0c;系统嘀嗒时钟假如用的是同一个内核那么里面相关的配置&…

Android问题笔记 - NoSuchmethodException: could not find Fragment constructor

点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册点击跳转>Scratch编程案例点击跳转>软考全系列 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&…

守护进程深度分析

思考 代码中创建的会话&#xff0c;如何关联控制终端&#xff1f; 新会话关联控制终端的方法 会话首进程成功打开终端设备 (设备打开前处于空闲状态) 1、关闭标准输入输出和标准错误输出2、将 stdin 关联到终端设备&#xff1a;STDIN_FILENO > 03、将 stdout 关联到终端设…

每日刷题|贪心算法初识

食用指南&#xff1a;本文为作者刷题中认为有必要记录的题目 推荐专栏&#xff1a;每日刷题 ♈️今日夜电波&#xff1a;悬溺—葛东琪 0:34 ━━━━━━️&#x1f49f;──────── 3:17 &#x1f…

idea中还原dont ask again

背景 在使用idea打开另外一个项目的时候&#xff0c;一不小心勾选为当前项目而且是不在下次询问&#xff0c;导致后面每次打开新的项目都会把当前项目关闭&#xff0c;如下图所示 下面我们就一起看一下如何把这个询问按钮还原回来 preferences/settings->Appearance&…

展馆导览系统之AR互动式导航与展品语音讲解应用

一、项目背景 随着科技的进步和人们对于文化、艺术、历史等方面需求的提升&#xff0c;展馆在人们的生活中扮演着越来越重要的角色。然而&#xff0c;传统的展馆导览方式&#xff0c;如纸质导览、人工讲解等&#xff0c;已无法满足参观者的多元化需求。为了提升参观者的体验&a…

vulnhub靶机Funbox11

下载地址&#xff1a;Funbox: Scriptkiddie ~ VulnHub 主机发现 arp-scan -l 目标192.168.21.164 端口扫描 nmap --min-rate 1000 -p- 192.168.21.164 端口好多处理一下吧 nmap --min-rate 1000 -p- 192.168.21.164 |grep open |awk -F / {print $1} |tr \n , 端口服务版本…

【ARM裸机】ARM入门

1.ARM成长史 2.ARM的商业模式和生态系统 ARM只设计CPU&#xff0c;但是不生产CPU 3.为什么使用三星&#xff1a;S5PV210 4.各种版本号 0. ARM和Cortex Cortex就是ARM公司一个系列处理器的名称。比如英特尔旗下处理器有酷睿&#xff0c;奔腾&#xff0c;赛扬。ARM在最初的处理器…

P1950 长方形

题目&#xff1a; P1950 长方形 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 算法&#xff1a; dp动态规划 代码&#xff1a; #include<iostream> #include<string> typedef unsigned long long ull; const int N 1010; using namespace std;int r, c, i, …