Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

XML 教程

XML 主页 XML 简介 XML 如何使用 XML 树 XML 语法 XML 元素 XML 属性 XML 命名空间 XML 显示 XML HttpRequest XML 解析器 XML DOM XML XPath XML XSLT XML XQuery XML XLink XML 验证器 XML DTD XML 架构 XML 服务器 XML 示例 XML 问答 XML 证书

XML AJAX

AJAX 简介 AJAX XMLHttp AJAX 请求 AJAX 响应 AJAX XML 文件 AJAX PHP AJAX ASP AJAX 数据库 AJAX 应用 AJAX 示例

XML DOM

DOM 简介 DOM 节点 DOM 访问 DOM 节点信息 DOM 节点列表 DOM 遍历 DOM 导航 DOM 获取值 DOM 修改节点 DOM 删除节点 DOM 替换节点 DOM 创建节点 DOM 添加节点 DOM 克隆节点 DOM 示例

XPath 教程

XPath 简介 XPath 节点 XPath 语法 XPath 轴 XPath 运算符 XPath 示例

XSLT 教程

XSLT 简介 XSL 语言 XSLT 转换 XSLT <template> XSLT <value-of> XSLT <for-each> XSLT <sort> XSLT <if> XSLT <choose> XSLT 应用 客户端 XSLT 服务器端 XSLT XSLT 编辑 XML XSLT 示例

XQuery 教程

XQuery 简介 XQuery 示例 XQuery FLWOR XQuery HTML XQuery 术语 XQuery 语法 XQuery 添加 XQuery 选择 XQuery 函数

XML DTD

DTD 简介 DTD 构建块 DTD 元素 DTD 属性 DTD 元素与属性 DTD 实体 DTD 示例

XSD 架构

XSD 简介 XSD 如何 XSD <schema> XSD 元素 XSD 属性 XSD 限制 XSD 复杂元素 XSD 空 XSD 仅元素 XSD 仅文本 XSD 混合 XSD 指示符 XSD <any> XSD <anyAttribute> XSD 替换 XSD 示例

XSD 数据类型

XSD 字符串 XSD 日期/时间 XSD 数值 XSD 其他 XSD 参考

Web 服务

XML 服务 XML WSDL XML SOAP XML RDF XML RSS

参考

DOM 节点类型 DOM 节点 DOM 节点列表 DOM NamedNodeMap DOM 文档 DOM 元素 DOM 属性 DOM 文本 DOM CDATA DOM 注释 DOM XMLHttpRequest DOM 解析器 XSLT 元素 XSLT/XPath 函数

AJAX - 发送 请求 到服务器


XMLHttpRequest 对象用于与服务器交换数据。


发送请求到服务器

要发送请求到服务器,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法

xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
方法 描述
open(method, url, async) 指定请求类型

method: 请求类型: GET 或 POST
url: 服务器 (文件) 位置
async: true (异步) 或 false (同步)
send() 将请求发送到服务器 (用于 GET)
send(string) 将请求发送到服务器 (用于 POST)

GET 或 POST?

GET 比 POST 更简单快捷,并且大多数情况下都可以使用。

但是,在以下情况下始终使用 POST 请求

  • 缓存文件不可用 (更新服务器上的文件或数据库)。
  • 向服务器发送大量数据 (POST 没有大小限制)。
  • 发送用户输入 (可能包含未知字符),POST 比 GET 更健壮和安全。

GET 请求

一个简单的 GET 请求

示例

xhttp.open("GET", "demo_get.asp", true);
xhttp.send();
亲自尝试 »

在上面的示例中,您可能会获得缓存的结果。为了避免这种情况,请在 URL 中添加一个唯一的 ID

示例

xhttp.open("GET", "demo_get.asp?t=" + Math.random(), true);
xhttp.send();
亲自尝试 »

如果您想使用 GET 方法发送信息,请将信息添加到 URL

示例

xhttp.open("GET", "demo_get2.asp?fname=Henry&lname=Ford", true);
xhttp.send();
亲自尝试 »


POST 请求

一个简单的 POST 请求

示例

xhttp.open("POST", "demo_post.asp", true);
xhttp.send();
亲自尝试 »

要像 HTML 表单一样 POST 数据,请使用 setRequestHeader() 添加 HTTP 头。在 send() 方法中指定要发送的数据

示例

xhttp.open("POST", "demo_post2.asp", true);
xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhttp.send("fname=Henry&lname=Ford");
亲自尝试 »
方法 描述
setRequestHeader(header, value) 向请求添加 HTTP 头

header: 指定头名称
value: 指定头值

url - 服务器上的文件

open() 方法的 url 参数是服务器上文件的地址

xhttp.open("GET", "ajax_test.asp", true);

该文件可以是任何类型的文件,例如 .txt 和 .xml,或服务器脚本文件,例如 .asp 和 .php (它们可以在发送响应之前执行服务器上的操作)。


异步 - True 或 False?

服务器请求应异步发送。

open() 方法的 async 参数应设置为 true

xhttp.open("GET", "ajax_test.asp", true);

通过异步发送,JavaScript 不必等待服务器响应,而是可以

  • 在等待服务器响应时执行其他脚本
  • 在响应准备就绪后处理响应

onreadystatechange 属性

使用 XMLHttpRequest 对象,您可以定义一个在请求收到响应时执行的函数。

该函数定义在 XMLHttpResponse 对象的 onreadystatechange 属性中

示例

xhttp.onreadystatechange = function() {
  if (this.readyState == 4 && this.status == 200) {
    document.getElementById("demo").innerHTML = this.responseText;
  }
};
xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
亲自尝试 »

上面的示例中使用的 "ajax_info.txt" 文件是一个简单的文本文件,内容如下

<h1>AJAX</h1>
<p>AJAX 不是一种编程语言。</p>
<p>AJAX 是一种从网页访问 web 服务器的技术。</p>
<p>AJAX 代表 Asynchronous JavaScript And XML。</p>

您将在后面的章节中学习更多关于 onreadystatechange 的知识。


同步请求

要执行同步请求,请将 open() 方法中的第三个参数更改为 false

xhttp.open("GET", "ajax_info.txt", false);

有时 async = false 用于快速测试。您还会在较旧的 JavaScript 代码中找到同步请求。

由于代码将等待服务器完成,因此无需使用 onreadystatechange 函数

示例

xhttp.open("GET", "ajax_info.txt", false);
xhttp.send();
document.getElementById("demo").innerHTML = xhttp.responseText;
亲自尝试 »

同步 XMLHttpRequest (async = false) 不推荐使用,因为 JavaScript 将停止执行,直到服务器响应准备就绪。如果服务器繁忙或速度慢,应用程序将挂起或停止。

同步 XMLHttpRequest 正在从 web 标准中删除,但这个过程可能需要很多年。

现代开发人员工具鼓励对使用同步请求发出警告,并在发生这种情况时可能会抛出 InvalidAccessError 异常。


×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.