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.rhkb.cn/news/169331.html

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

相关文章

CI2454 2.4g无线MCU芯片应用

Ci2454集成MCU芯片 | Ci2454是一款集成无线收发器和 8 位 RISC&#xff08;精简指令集&#xff09;MCU 的SOC芯片。 #Ci2454芯片 集成MCU芯片# 中国芯片# 无线收发器特性&#xff1a; 工作在 2.4GHz ISM 频段 调制方式&#xff1a;GFSK/FSK 数据速率&#xff1a;2Mbps/1Mbps…

虚拟世界游戏定制开发:创造独一无二的虚拟体验

在游戏开发领域&#xff0c;虚拟世界游戏定制开发是一项引人注目的任务&#xff0c;旨在满足客户独特的需求和愿景&#xff0c;创造一个完全个性化的虚拟世界游戏。这种类型的游戏开发需要专业的技能、深刻的游戏开发知识和密切的与客户合作&#xff0c;以确保游戏满足客户的期…

金蝶云星空企业版v8.0内网穿透配置详解:实现便捷的异地远程访问

文章目录 前言1. 金蝶云星空企业版v8.0安装下载1.1 登录金蝶官网下载安装包1.2 常见的安装下载问题 2. 金蝶云星空配置SQL Sever数据库2.1 创建数据管理中心2.2 创建完成后在服务器登录管理站点 3. 下载安装注册cpolar3.1 公网访问测试 4. 固定连接公网地址 前言 金蝶云星空专注…

统信UOS技术开放日:四大领域全面接入AI大模型能力

1024是程序员的节日&#xff0c;10月24日&#xff0c;统信举办2023统信UOS技术开放日暨deepin Meetup北京站活动&#xff0c;发布与大模型同行的UOS AI、浏览器AI助手、邮箱AI助手、自然语言全局搜索、畅写在线等多项最新AI技术与产品应用。 统信软件高级副总经理、CTO、深度社…

Bootstrap的列表组相关知识

目录 01-列表组的相关基础知识02-一个简单的列表组示例03-激活或禁用列表组的一行或多行04-设置列表项的颜色05-给列表项添加徽章 01-列表组的相关基础知识 Bootstrap的list-group是一个用于创建列表组件的CSS类&#xff0c;通常用于显示一个项目列表&#xff0c;如导航菜单或…

DataX 数据迁移

1、前期准备 Linux系统 Python&#xff08;最好是2&#xff09; Jdk 1.8以上 2、安装Python2 --更新软件包 sudo apt update --安装python2 sudo apt install python2 --查看python版本 python2 --version 3、下载DataX Linux下载DataX wget http://datax-opensource.o…

制药企业固体制剂设备管理及维护要点

在制药企业的生产过程中&#xff0c;固体制剂设备是至关重要的一环。有效管理和维护这些设备对于确保生产质量、提高生产效率以及延长设备寿命至关重要。本文将从以下三个方面介绍制药企业固体制剂设备的主要类型、常见管理问题以及设备维护的关键要点。 制药企业固体制剂设备主…

ChatGPT 助力英文论文翻译和润色

文章目录 一、前言二、主要内容1. 中英互译2. 中文润色3. 英文润色 三、总结 &#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 一、前言 随着全球化的推进&#xff0c;跨文化交流变得越来越重要。在学术领域&#xff0c;英文论文的质量对于研究成果的传…

订水商城H5实战教程-03用户协议

目录 1 创建页面2 为文本组件增加事件3 检查用户协议是否勾选最终效果 我们上一篇介绍了打开首页时弹出登录窗口的功能&#xff0c;本篇我们实现一下用户协议。 1 创建页面 功能是点击用户协议的时候打开具体的协议内容&#xff0c;需要先创建一个页面。打开自定义应用&#x…

【FPGA】IIC协议通用主机接口的设计与实现详解

一、认识IIC IIC&#xff08;I2C&#xff09;协议是一种串行通信协议&#xff0c;用于连接微控制器和外围设备。IIC协议只需要两根信号线&#xff08;时钟线SCL和数据线SDA&#xff09;就能完成设备之间的通信&#xff1b;支持多主机和多从机通信&#xff0c;通过设备地址区分不…

C++栈、队列、优先级队列模拟+仿函数

目录 一、栈的模拟和deque容器 1.deque 1.1deque结构 1.2deque优缺点 2.stack模拟 二、队列的模拟 三、priority_queue优先级队列 1.优先级队列模拟 2.添加仿函数 一、栈的模拟和deque容器 在之前&#xff0c;我们学过了C语言版本的栈&#xff0c;可以看这篇文章 栈和…

java智慧工地云平台源码,以物联网、移动互联网技术为基础,结合大数据、云计算等,实现工程管理绿色化、数字化、精细化、智能化的效果

智慧工地将更多人工智能、传感技术、虚拟现实等高科技技术植入到建筑、机械、人员穿戴设施、场地进出关口等各类物体中&#xff0c;围绕人、机、料、法、环等各方面关键因素&#xff0c;彻底改变传统建筑施工现场参建各方现场管理的交互方式、工作方式和管理模式&#xff0c;智…

香飘飘的想象空间:全面创新驱动外延与内涵双增长,未来可期

面对时常会发生代际更替的消费者主力群体&#xff0c;创新已经成为一种商业上的必须。 日前&#xff0c;香飘飘发布了三季报&#xff0c;数据显示&#xff0c;第三季度&#xff0c;香飘飘营业收入8.08亿元&#xff0c;同比增长20.41%。前三季度&#xff0c;香飘飘营收19.79亿元…

视频号视频提取小程序,快速下载视频号视频

​视频号提取小程序可以帮助用户方便地从视频号视频平台获取到自己喜欢的视频号内容。通过这个小程序&#xff0c;你可以快速搜索并提取出视频号&#xff0c;并进行相关的操作。 据悉视频下载bot小程序目前已经更名为【提取下载小助手】 使用视频号提取小程序有以下几个步骤&…

Kubernetes 通过 Deployment 部署Jupyterlab

概要 在Kubernetes上部署jupyterlab服务&#xff0c;链接Kubernetes集群内的MySQL&#xff0c;实现简单的数据开发功能。 前置条件 镜像准备&#xff1a;自定义Docker镜像--Jupyterlab-CSDN博客 MySQL-Statefulset准备&#xff1a;StatefulSet 简单实践 Kubernetes-CSDN博客…

学习vue3

一、入门 1.引入外部库 ①直接将所有的js都通过script标签引入到html文件中&#xff0c;所有的js资源在web页面中都能通用。 ②使用js引用js&#xff08;ES6&#xff09;&#xff0c;模块导入与导出 2.模块是只读引用 这段话是在解释 Vue.js 中的概念和用法。在 Vue.js 中&a…

从实时数据库转战时序数据库,他陪伴 TDengine 从 1.0 走到 3.0

关于采访嘉宾 在关胜亮的学生时代&#xff0c;“神童”这个称号如影随形&#xff0c;很多人初听时会觉得这个称谓略显夸张&#xff0c;有些人还会认为这是不是就是一种调侃&#xff0c;但是如果你听说过他的经历&#xff0c;就会理解这一称号的意义所在了。 受到教师母亲的影…

React之render

一、原理 首先&#xff0c;render函数在react中有两种形式&#xff1a; 在类组件中&#xff0c;指的是render方法&#xff1a; class Foo extends React.Component {render() {return <h1> Foo </h1>;} }在函数组件中&#xff0c;指的是函数组件本身&#xff1a…

【Linux进阶之路】进程(中)—— 进程地址空间

文章目录 一、 进程地址空间1.概念引入2.基本概念3.深入概念3.1 初识信息交互3.2 区域划分3.3 进程地址空间3.4 再识页表缺页中断进程挂起 总结 一、 进程地址空间 1.概念引入 指针指向的地址是内存中的地址吗&#xff1f;下面我们用一个实验来证明一下。 先来写程序看一下程…

C# Onnx Yolov8 Detect 戴安全帽检测

效果 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms;namespace Onnx…