最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

非常简单的Ajax请求实例附源码

来源:懂视网 责编:小采 时间:2020-11-27 22:52:03
文档

非常简单的Ajax请求实例附源码

非常简单的Ajax请求实例附源码:Ajax不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。通过Ajax,您可以使用 JavaScript的XMLHttpRequest对象来直接与服务器进行通信。您可以在不重载页面的情况与 Web 服务器交换数据。在本文的例子中,我们将演示当用户
推荐度:
导读非常简单的Ajax请求实例附源码:Ajax不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。通过Ajax,您可以使用 JavaScript的XMLHttpRequest对象来直接与服务器进行通信。您可以在不重载页面的情况与 Web 服务器交换数据。在本文的例子中,我们将演示当用户

Ajax不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。通过Ajax,您可以使用 JavaScript的XMLHttpRequest对象来直接与服务器进行通信。您可以在不重载页面的情况与 Web 服务器交换数据。在本文的例子中,我们将演示当用户向一个标准的HTML表单中输入数据时网页如何与web服务器进行通信。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>简单的Ajax请求</title>
 <script type="text/javascript">
 var xmlHttp;
 // 创建XMLHttpRequest对象
 function createXMLHttpRequest() {
 if (window.ActiveXObject) {
 xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
 }
 else if (window.XMLHttpRequest) {
 xmlHttp = new XMLHttpRequest();
 }
 }
 // 整合url参数
 function createQueryString() {
 var name = document.getElementById("txtName").value;
 var sex = document.getElementById("txtSex").value;
 var birthday = document.getElementById("txtBirthday").value;
 var queryString = "Name=" + encodeURIComponent(name) + "&Sex=" + encodeURIComponent(sex) + "&Birthday=" + encodeURIComponent(birthday);
 return queryString;
 }
 // 按照Get方式传递参数
 function doRequestUsingGET() {
 createXMLHttpRequest();
 var queryString = "AjaxServer.ashx?";
 queryString = queryString + createQueryString() + "&timeStamp=" + new Date().getTime();
 xmlHttp.onreadystatechange = handleStateChange;
 xmlHttp.open("GET", queryString, true);
 xmlHttp.send(null);
 }
 // 按POST方式传递参数
 function doRequestUsingPOST() {
 createXMLHttpRequest();
 var url = "AjaxServer.ashx?timeStamp=" + new Date().getTime();
 var queryString = createQueryString();
 xmlHttp.open("POST", url, true);
 xmlHttp.onreadystatechange = handleStateChange;
 xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;");
 xmlHttp.send(queryString);
 }
 // 回调函数
 function handleStateChange() {
 if (xmlHttp.readyState == 4) {
 if (xmlHttp.status == 200) {
 parseResults();
 }
 }
 }
 // 处理服务器响应内容
 function parseResults() {
 var responseDiv = document.getElementById("serverResponse");
 if (responseDiv.hasChildNodes()) {
 responseDiv.removeChild(responseDiv.childNodes[0]);
 }
 var responseText = document.createTextNode(xmlHttp.responseText);
 responseDiv.appendChild(responseText);
 }
 </script>
</head>
<body>
 <form action="#">
 <h2>输入你的名字,性别,生日:</h2>
 <table>
 <tr><td>名字:</td><td><input type="text" id="txtName" /></td></tr>
 <tr><td>性别:</td><td><input type="text" id="txtSex" /></td></tr>
 <tr><td>生日:</td><td><input type="text" id="txtBirthday" /></td>
 </tr>
 </table>
 <input type="button" value="用Get方式传参数" onclick="doRequestUsingGET();"/>
 <br /><br />
 <input type="button" value="用POST方式传参数" onclick="doRequestUsingPOST();"/>
 </form>
 <br />
 <h3>服务器响应内容:</h3>
 <div id="serverResponse"></div>
</body>
</html>

下面来详细说明每个JS函数的功能。
createXMLHttpRequest() 用来创建XMLHttpRequest对象。
因为IE把XMLHttpRequest实现为一个ActiveX对象,其他浏览器(FF/Safari/Opera)把它实现为一个本地JavaScript对象。由于存在这些差别,JavaScript代码中必须包含有关的逻辑。
createQueryString() 用来整理参数,将Ajax请求要传递的参数整理成一定的格式。
如果传递中文或非ASCII字符必须进行URL编码,本例使用JS的encodeURIComponent()函数进行参数URL编码。
doRequestUsingGET() 以HTTP GET方式向服务器发送请求,并且传递参数。
XMLHttpRequest对象的open()方法会指定将发出的请求。open()方法取3个参数:一个是指示所使用的方法(通常是GET或POST)的串;一个是表示目标资源URL的串;一个是Boolean值,只是请求是否是异步的。
GET请求时,将传递的参数写到open方法的url参数中,此时send方法的参数为null。
在某些情况下,有些浏览器会把多个XMLHttpRequest请求的结果缓存在同一个URL。如果对每个请求的响应不同,这就会带来不好的结果,把当前时间戳追加到URL的最后,就能确保URL的惟一性,从而避免浏览器缓存结果。
本例服务器端代码使用的是asp.net(c#)。
doRequestUsingPOST() 以HTTP POST方式向服务器发送请求,并且传递参数。
确保open()中指定的方法是POST,需要设定Content-Type头信息,模拟HTTP POST方法发送一个表单,这样服务器才会知道如何处理上传的内容。设置头信息前必须先调用open方法。
必须使用send方法传递参数。参数的提交格式和GET方法中url的写法一样。
handleStateChange()  Ajax回调函数。
对于XMLHttpRequest对象,onreadystatechange属性存储了回调函数的指针。当XMLHttpRequest对象内部状态发生变化时,就会调用这个回调函数。
parseResults() 处理响应结果。

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

非常简单的Ajax请求实例附源码

非常简单的Ajax请求实例附源码:Ajax不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。通过Ajax,您可以使用 JavaScript的XMLHttpRequest对象来直接与服务器进行通信。您可以在不重载页面的情况与 Web 服务器交换数据。在本文的例子中,我们将演示当用户
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top