status 返回请求的状态码 statusText 返回状态文本(例如 "OK" 或 "Not Found"...当 readyState 为 4 且 status 为 200 时,表示响应已准备好。...当服务器响应就绪时,myFunction() 函数会解析XML并构建一个包含CD信息的HTML表格,最终更新具有 "demo" ID 的元素。..."getcustomer.php" 中的源代码针对数据库运行一个查询,并以 HTML 表格的形式返回结果: 在上述示例中,当用户选择一个客户时,通过AJAX与服务器通信,并从数据库中获取相应的客户信息。客户信息将以HTML表格的形式显示在具有 "txtHint" ID 的元素中。
在等待服务器响应时执行其他脚本 当响应就绪后对响应进行处理 Async = true 当使用 async=true 时,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数...然而,在以下情况中,请使用 POST 请求: 无法使用缓存文件(更新服务器上的文件或数据库) 向服务器发送大量数据(POST 没有数据量限制) 发送包含未知字符的用户输入时,POST...-数据接收完毕,此时可以通过通过responseBody和responseText获取完整的回应数据 status: 200: "OK" 404: 未找到页面 注释:onreadystatechange...当 readyState 等于 4 且状态为 200 时,表示响应已就绪: xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState...演示结果: 返回结果为200-正确的页面: ? 返回结果为500-错误的页面: 让servlet出一个异常就可以模仿出来了。 例如:int a=12/0; ?
一、什么是Ajax Ajax 的全称是 Asynchronous JavaScript and XML(即异步的 JavaScript 和 XML),是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术...(JSON) 6、使用 JavaScript 和 DOM 实现局部刷新 四、Ajax中的一些处理总结 1、服务器响应处理 responseText:获得字符串形式的响应数据 responseXML:获得...属性改变时,就会调用该函数 readyState:存有 XMLHttpRequest 的状态 0:请求未初始化 1:服务器连接已建立 2:请求已接收 3:请求处理中 4:请求已完成,且响应已就绪...比较常见的有: 200:“OK”(当 readyState 等于 4 且状态为 200 时,表示响应已就绪) 304:该资源在上次请求之后没有任何修改(这通常用于浏览器的缓存机制,使用GET请求时尤其需要注意...) 403:(禁止) 服务器拒绝请求 404:(未找到) 服务器找不到请求的网页 408:(请求超时) 服务器等候请求时发生超时 500:(服务器内部错误) 服务器遇到错误,无法完成请求
众所周知,HTTP协议是无状态的,所以一次的请求都是一个单独的事件,和前后都没有联系。所以我们在解决网页实时聊天时就遇到一个问题,如何保证与服务器的长时间联系,从而源源不段地获取信息。...这篇博文总结一下用JS和JQ两种方式(其实不同就是js和jq的实现),实现AJAX长轮询。 长轮询的思想: ? 如图:用AJAX发送询问信息,服务器在没有信息要返回的时候进入无限等待。...=0){ //当有未读信息时读取信息 $link->query($change);//将信息的已读flag设为1 $msg=$res->fetch_assoc...} 客户端实现: 客户端的主要任务是设置一个ajax请求函数,每次查询时被调用,当没有信息返回时,服务器端被搁置,当前页面正常执行;当有信息返回时,函数处理返回的数据,并迅速再次调用此函数发送一次请求。.../x-www-form-urlencoded"); 聊天室消息处理: 为了防止每次都查询到全部信息,我们对数据库的查询操作更改一下,设置idflag=0,每次查询后,设置idflag为查询到的数据的id
它可以发送和接收各种格式的信息,包括JSON,XML,HTML和文本文件。AJAX最吸引人的特点是其“异步”特性,这意味着它可以与服务器通信,交换数据和更新页面,而不必刷新页面。...可选的第三个参数设置请求是否异步。如果true(默认),则将继续执行JavaScript,并且用户可以在服务器响应尚未到达时与页面进行交互。这是AJAX中的第一个A。...可能的代码在W3C上列出。在以下示例中,我们通过检查200 OK响应代码来区分AJAX调用成功与否。...JavaScript DOM函数遍历的对象返回 请注意,仅当您使用了异步请求(open()未指定的第三个参数或将其设置为true)时,以上步骤才有效。...在包含AJAX函数httpRequest 的闭包中声明局部变量可以避免这种情况。 如果发生通信错误(例如服务器关闭),则onreadystatechange在访问响应状态时,方法中将引发异常。
而传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。 还有为什么叫异步呢? 因为在加载的时候,页面的其他部分还是可以自由操作的,没有出现卡死的状态,所以是异步。...status:服务器返回的状态码 this.status == 200:表示响应成功;404 表示没有找到请求的资源;500 表示服务器端错误。...readyState: xhr对象的状态改变时,readyState的值也会相应的改变。...send 方法已经被调用,已经可以获取状态行和响应头 3 LOADING 响应体下载中,responseText 属性可能已经包含部分数据 4 DONE 响应体下载完成,可以直接调用 responseText...当 readyState == 3 时,可能已经获取部分数据体,但是处理数据是不可靠的,所以一般一般我们都是在 readyState 值为 4 时,执行响应的后续逻辑 。
如果按照HTTP方法的语义来暴露资源,那么接口将会拥有安全性和幂等性的特性,例如GET和HEAD请求都是安全的, 无论请求多少次,都不会改变服务器状态。...下面列出了GET,DELETE,PUT和POST的典型用法: GET 安全且幂等 获取表示 变更时获取表示(缓存) 200(OK) - 表示已在响应中发出 204(无内容) - 资源有空表示 301(...,则不过更新资源(乐观锁) 200(OK)- 如果现有资源已被更改 201(created)- 如果新资源被创建 202(accepted)- 已接受处理请求但尚未完成(异步处理) 301(Moved...服务当前无法处理请求 PUT 不安全但幂等 用客户端管理的实例号创建一个资源 通过替换的方式更新资源 如果未被修改,则更新资源(乐观锁) 200 (OK)- 如果已存在资源被更改 201 (created...)- 服务当前无法处理请求 DELETE 不安全但幂等 删除资源 200 (OK)- 资源已被删除 301 (Moved Permanently)- 资源的URI已更改 303 (See Other)
常见状态码: 状态码 含义 说明 200 OK 操作成功, 并返回数据 201 CREATED 新建成功 204 NO CONTENT 删除成功 400 BAD REQUEST 请求语法错误 403 Forbidden...503 (Service Unavailable)- 服务端当前无法处理请求 POST 200(OK)- 如果现有资源已被更改 201(created)- 如果新资源被创建 202(accepted...)- 服务当前无法处理请求 PUT 200 (OK)- 如果已存在资源被更改 201 (created)- 如果新资源被创建 301(Moved Permanently)- 资源的URI已更改...)- 服务当前无法处理请求 DELETE 200 (OK)- 资源已被删除 301 (Moved Permanently)- 资源的URI已更改 303 (See Other)- 其他,如负载均衡...– 返回204状态码+空文档 实际开发中,通常会将 状态码、错误信息、返回数据,都放到返回结果中。
1.2.2 响应消息 响应状态行 响应头 实体内容 // 响应状态行 // HTTP/1.1 200 OK // 响应头 // Date: Thu, 02 Nov 2017 06:22:27 GMT /...DOCTYPE html> // 响应状态行 HTTP版本:例如,HTTP/1.1。 状态码:例如,200。 描述信息:例如 OK 。...例如,当请求成功时,状态码为200。 另外还有一个类似的属性statusText,值为字符型数据,包含了描述短语,如“200 OK”。...-- 结束标签 --> 当服务器返回的是一个XML格式的数据时,利用Ajax对象的responseXML属性即可对XML数据进行处理。...当需要发送多个JSONP请求时,无法区分每个回调函数。 为了解决这两个问题,我们可以编写代码实现自动生成一个随机的回调函数名,并在请求时将函数名传递给服务器,服务器在返回结果中调用指定的函数。
(对低版本的 ie 不作兼容处理了,太过时,不知道谁还用) 本次演示采用原生javascript + php 实现ajax的 post 和 get 功能; 对php不了解的同学不用担心,就两三行代码..., 默认打开的是index.html文件; 1.AJAX get :(不传递参数)当我点击页面中的按钮时,获取后台数据,...if(request.readyState==4){ //status 状态200 代表 ok...open ( “POST” , “data.php” , true ); 其它的全部一样; 3.AJAX get :(传递参数) 当我点击页面中的按钮时...if ( request .readyState == 4 ){ //status 状态200 代表 ok if ( request .status == 200
其实我们在进行任何操作的时候,前端都会向后端发送一个请求,后端接收到请求后会向前端送回响应。在这个过程中我们就需要ajax。 同步和异步 在讲ajax之前我们要了解一个很重要的概念。...这意味着用户可以享受到更快、更流畅的网页体验,因为只有需要更新的数据会被请求和交换,而不是重新加载整个页面 ajax的工作流程 1.创建XMLHttpRequest对象 let xhr = new XMLHttpRequest...== 200) {}//拿到了后端数据 onreadystatechange = ()可以监听请求状态,当xhr.readyState == 4 || xhr.status == 200的时候表示成功了...,不同的状态码代表不同的状态如: 1xx 响应中——临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它 2xx 成功——表示请求已经被成功接收,处理已完成 3xx 重定向——...版本不支持等 200 OK 客户端请求成功,即处理成功,这是我们最想看到的状态码 302 Found 指示所请求的资源已移动到由Location响应头给定的 URL,浏览器会自动重新访问到这个页面 304
二.Ajax的原生写法 1.XMLHttpRequest对象 XMLHttpRequest 对象用于在后台与服务器交换数据,能够在不重新加载页面的情况下更新网页,在页面已加载后从服务器请求数据,在页面已加载后从服务器接收数据...) //当满足这两个条件时表示请求成功,完成响应 4 = "loaded", 200 = OK { var data=xmlhttp.responseText; //拿到服务器返回的数据...(3).关于status 由服务器返回的 HTTP 状态代码,200 表示成功,而 404 表示 "Not Found" 错误。当 readyState 小于 3 的时候读取这一属性会导致一个异常。...跨域访问时一个很重要的知识点,之前专门写过一篇关于跨域访问的总结,还挺详细的,可以移步查看: javascript中实现跨域的方式总结 九.再议HTTP状态码 前面提到的"200"、"404"只是http...状态码中常见的两个,当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。
一、什么是 AJAX 1.为什么需要AJAX 当需要从服务器获取数据,并刷新页面的操作,如果不采用AJAX,则需要用提交整个表单的方式,当提交表单时,发送请求给服务器,页面需要等待服务器发送完response...有5个可取值:0 = 未初始化,1 = 正在加载,2 = 已加载,3 = 交互中,4 = 完成 responseText 服务器的响应,返回数据的文本。...responseBody 服务器返回的主题(非文本格式) responseStream 服务器返回的数据流 status 服务器的HTTP状态码(如:404 = "文件末找到" 、200 ="成功" ,...等等) statusText 服务器返回的状态文本信息 ,HTTP状态码的相应文本(OK或Not Found(未找到)等等) 五、JQuery实现AJAX 下面的代码实现了当切换DropDownList...页面的内容全部由JAVAScript来控制,服务端负责逻辑的校验和从数据库中拿数据。
概要 Ajax是“Asynchronous JavaScript and XML”的简称,即异步的JavaScript和XML。 readyState属性用来返回当前的请求状态,有五个可选值。...3:“正在接收”状态,表示已经接收到HTTP响应头的信息,但是消息体部分还没有完全接收。 4:“已加载”状态,表示响应已经被完全接收。...status属性用来返回服务器的响应状态码,例如200表示OK,一切正常;404表示请求的文件没有找到;500表示内部服务器发生错误等。...例如,statusText值为OK时,表示一切正常,对应status为200;值为Not Found表示文件没有找到,对应status为404。...responseXML用来接收服务器的响应,以XML的形式存在,这个对象可以解析为一个DOM对象,进一步使用DOM的API更新客户端页面。
它可以使用JSON,XML,HTML和文本等多种格式发送和接收。AJAX最吸引人的就是它的“异步”特性,也就是说他可以在不重新刷新页面的情况下与服务器通信,交换数据,更新页面。...在这一阶段,你要告诉XMLHttp请求对象是由哪一个JavaScript函数处理响应,在设置了对象的 onreadystatechange属性后给他命名,当请求状态改变时调用函数。...在下面的例子中,我们通过检查响应码 200 OK 区别对待成功和不成功的AJAX调用。 if (httpRequest.status === 200) { // Perfect!...alertContents() 检查返回的响应是否OK,然后 alert() test.html 文件内容。...你也可以添加一个总是不同的 GET 参数,比如时间戳或者随机数 。 在通信错误的事件中(例如服务器宕机),在访问响应状态 onreadystatechange 方法中会抛出一个例外。
什么是AJAX?AJAX(Asynchronous JavaScript and XML)是一种无需重新加载整个页面就能与服务器交换数据和更新部分网页的技术。...通过在后台与服务器进行少量数据交换,AJAX可以使网页实现异步更新,这意味着可以在不干扰用户操作的情况下更新页面内容。...最后,我们使用.catch捕获任何可能发生的错误。常见问题与易错点忽略HTTP状态码:在使用Fetch API时,应始终检查HTTP状态码。例如,200表示请求成功,而404表示未找到资源。...}) // ...后续处理错误处理:在处理Promise链时,应始终包含.catch块来捕获任何可能发生的错误。...然而,在使用Fetch API时,需要注意检查HTTP状态码、正确处理错误、处理跨域请求问题、发送Cookie以及实现请求超时等常见问题。
Ajax Ajax介绍 AJAX是异步的JavaScript和XML(Asynchronous JavaScript And XML)。...它可以使用JSON,XML,HTML和text文本等格式发送和接收数据。AJAX最吸引人的就是它的“异步”特性,也就是说它可以在不重新刷新页面的情况下与服务器通信,交换数据,或更新页面。...你要告诉XMLHttp请求对象是由哪一个js函数处理响应,在设置了对象的 onreadystatechange属性后给他命名,当请求状态改变时调用函数。...首先,函数要检查请求的状态。可以通过检查返回的状态码 200 OK 来判断AJAX是否成功 if (httpRequest.status === 200) { // Perfect!...这里向服务器跨域发送,发现在浏览器会报错 但服务器依旧是收到了来自客户端的数据 0x04 小结 Ajax在异步处理中占据着举足轻重的地位,向在XSS中可向自己的服务器发送相关的数据等等。
(1)200 OK200 OK表示客户端发来的请求被服务器端正常处理了。...该状态码表示客户端发送附带条件的请求时,服务器端允许请求访问资源,但未满足条件的情况。304 状态码返回时,不包含任何响应的主体部分。304 虽然被划分在 3XX 类别中,但是和重定向没有关系。...当错误发生时,需修改请求的内容后再次发送请求。另外,浏览器会像 200 OK 一样对待该状态码。...完成模板中的html渲染到html 页面中。此过程中进行ajax交互。5、beforeUpdate(更新前) :响应式数据更新时调用,此时虽然响应式数据更新了,但是对应的真实 DOM 还没有被渲染。...6、updated(更新后):在由于数据更改导致的虚拟DOM重新渲染和打补丁之后调用。此时 DOM 已经根据响应式数据的变化更新了。调用时,组件 DOM已经更新,所以可以执行依赖于DOM的操作。
创建AJAX对象 发出HTTP请求 接收服务器传回的数据 更新网页数据 概括起来,就是一句话,AJAX通过原生的XMLHttpRequest对象发出HTTP请求,得到服务器返回的数据后,再进行处理。...2、status 只读属性,表示本次请求所得到的HTTP状态码,返回一个整数。一般来说,如果通信成功的话,这个状态码是200。...常用的有如下几个状态码: 200:OK(正常访问); 301:Moved Permanently(永久移动); 302:Moved temporarily(暂时移动); 304:Not Modified...); 基本上,只有200和304的状态码,表示服务器返回是正常状态。...| 3、 statusText 与status属性类似,返回本次请求的状态,不同点在于,status只返回一个数字,而该属性返回一个字符串 ,包含整个状态信息,比如”200 OK“| 4、responseType