菜单
×
   ❮     
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 HOME XML Introduction XML How to use XML Tree XML Syntax XML Elements XML Attributes XML Namespaces XML Display XML HttpRequest XML Parser XML DOM XML XPath XML XSLT XML XQuery XML XLink XML Validator XML DTD XML Schema XML Server XML Examples XML Quiz XML Certificate

XML AJAX

AJAX Introduction AJAX XMLHttp AJAX Request AJAX Response AJAX XML File AJAX PHP AJAX ASP AJAX Database AJAX Applications AJAX Examples

XML DOM

DOM Introduction DOM Nodes DOM Accessing DOM Node Info DOM Node List DOM Traversing DOM Navigating DOM Get Values DOM Change Nodes DOM Remove Nodes DOM Replace Nodes DOM Create Nodes DOM Add Nodes DOM Clone Nodes DOM Examples

XPath 教程

XPath Introduction XPath Nodes XPath Syntax XPath Axes XPath Operators XPath Examples

XSLT 教程

XSLT Introduction XSL Languages XSLT Transform XSLT <template> XSLT <value-of> XSLT <for-each> XSLT <sort> XSLT <if> XSLT <choose> XSLT Apply XSLT on the Client XSLT on the Server XSLT Edit XML XSLT Examples

XQuery 教程

XQuery Introduction XQuery Example XQuery FLWOR XQuery HTML XQuery Terms XQuery Syntax XQuery Add XQuery Select XQuery Functions

XML DTD

DTD Introduction DTD Building Blocks DTD Elements DTD Attributes DTD Elements vs Attr DTD Entities DTD Examples

XSD Schema

XSD Introduction XSD How To XSD <schema> XSD Elements XSD Attributes XSD Restrictions XSD Complex Elements XSD Empty XSD Elements-only XSD Text-only XSD Mixed XSD Indicators XSD <any> XSD <anyAttribute> XSD Substitution XSD Example

XSD Data Types

XSD String XSD Date/Time XSD Numeric XSD Misc XSD Reference

Web Services

XML Services XML WSDL XML SOAP XML RDF XML RSS

参考手册

DOM Node Types DOM Node DOM NodeList DOM NamedNodeMap DOM Document DOM Element DOM Attribute DOM Text DOM CDATA DOM Comment DOM XMLHttpRequest DOM Parser XSLT Elements XSLT/XPath Functions

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 对象,您可以定义一个在请求收到答案时执行的函数。

该函数在 XMLHttpRequest 对象的 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(异步 JavaScript 和 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 异常。


×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持