chy710's Tech Space

博客园 首页 新随笔 联系 订阅 管理
  80 Posts :: 10 Stories :: 268 Comments :: 26 Trackbacks

一、XMLHttpRequest 对象的方法与属性

   

   

abort()

停止当前请求

getAllResponseHeaders()

HTTP请求的所有响应首部作为键/值对返回

getResponseHeader("header")

返回指定首部的串值

open("method", "url")

建立对服务器的调用。method参数可以是GETPOSTPUTurl参数可以是相对URL或绝对URL。这个方法还包括3个可选的参数

send(content)

向服务器发送请求

setRequestHeader("header", "value")

把指定首部设置为所提供的值。在设置任何首部之前必须先调用open()


  属 

   

onreadystatechange

每个状态改变时都会触发这个事件处理器,通常会调用一个JavaScript函数

readyState

请求的状态。有5个可取值:0 = 未初始化,1 = 正在加载,2 = 已加载,3 = 交互中,4 = 完成

responseText

服务器的响应,表示为一个串

responseXML

服务器的响应,表示为XML。这个对象可以解析为一个DOM对象

status

服务器的HTTP状态码(200对应OK404对应Not Found(未找到),等等)

statusText

HTTP状态码的相应文本(OKNot Found(未找到)等等)


二、使用XMLHttpRequest 实现ajax效果
这里我们用客户端通过XMLHttpRequest 请求服务端获取当前系统时间,实现异步交互!
客户端myAjax.html代码
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    
<title>xmlhttprequest ajax demo</title>
    
<script type ="text/javascript" language ="javascript" >
        
var req; //定义变量,用来创建xmlhttprequest对象
        function creatReq() // 创建xmlhttprequest,ajax开始
        {
            
var url="ajaxServer.aspx"//要请求的服务端地址
            if(window.XMLHttpRequest) //非IE浏览器,用xmlhttprequest对象创建
            {
                req
=new XMLHttpRequest();
            }

            
else if(window.ActiveXObject) //IE浏览器用activexobject对象创建
            {
                req
=new ActiveXObject("Microsoft.XMLHttp");
            }

            
            
if(req) //成功创建xmlhttprequest
            {
                req.open(
"GET",url,true); //与服务端建立连接(请求方式post或get,地址,true表示异步)
                req.onreadystatechange = callback; //指定回调函数
                req.send(null); //发送请求
            }

        }

        
        
function callback() //回调函数,对服务端的响应处理,监视response状态
        {
            
if(req.readystate==4//请求状态为4表示成功
            {
                
if(req.status==200//http状态200表示OK
                {
                    Dispaly(); 
//所有状态成功,执行此函数,显示数据
                }

                
else //http返回状态失败
                {
                    alert(
"服务端返回状态" + req.statusText);
                }

            }

            
else //请求状态还没有成功,页面等待
            {
                document .getElementById (
"myTime").innerHTML ="数据加载中";
            }

        }

        
        
function Dispaly() //接受服务端返回的数据,对其进行显示
        {
            document .getElementById (
"myTime").innerHTML =req.responseText;
        }

        
    
</script>
</head>
<body>
    
<div id="myTime"></div>
        
    
<input id="Button1" type="button" value="Get Time"  onclick ="creatReq();"/>
</body>
</html>
服务端ajaxServer.aspx代码
public partial class ajaxServer : System.Web.UI.Page
{
    
protected void Page_Load(object sender, EventArgs e)
    
{
        System.Threading.Thread.Sleep(
1000); //为了看到ajax效果,将当前线程延时1000毫秒
        Response.Write(DateTime .Now .ToString ()); //输出当前时间
    }

}
运行效果:

posted on 2007-04-15 09:23 chy710 阅读(4182) 评论(12)  编辑 收藏 所属分类: Ajax

Feedback

#1楼  2007-10-25 16:44 LGQ [未注册用户]
我把你的代码直接拷上去,最后XMLHTTPREQUEST返回的是整个页面的HTML代码 并没有返回时间
你的效果怎么做的啊
  回复  引用    

#2楼  2008-03-29 16:28 xudi [未注册用户]
程序有点问题
问题处在 <input id="Button1" type="button" value="Get Time" onclick ="creatReq();"/>
改为<input id="Button1" type="button" value="Get Time" onclick ="creatReq('ajaxServer.aspx');"/>

例子很不错


  回复  引用    

#3楼  2008-05-17 22:07 wang_deu [未注册用户]
为什么我的 req.readystate 这个值总是0 呢,
是不是我的 .net 环境 需要什么设置啊。
这个问题困扰我好久了,不能继续学习 Ajax了
  回复  引用    

#4楼 [楼主] 2008-05-20 09:24 chy710      
@wang_deu

请求的状态未初始化,检查一下代码:
myAjax.html
ajaxServer.aspx 有后端cs代码
客户端myAjax.html访问服务端ajaxServer.aspx,返回数据,再更新html页面,整个过程就是这样的.
  回复  引用  查看    

#5楼  2008-06-22 01:51 闲聊 [未注册用户]
例子没错!真的!不过在CS代码里面加上Response.End();就能显示了!
  回复  引用    

#6楼  2008-06-23 10:05 王志伟1 [未注册用户]
谢谢楼主,将你的代码稍微修改了一下,可以指定aspx页面和显示的div
调用方法 onclick ="creatReq('receive.aspx','div1');"

<script type ="text/javascript" language ="javascript" >
var req; //定义变量,用来创建xmlhttprequest对象
var divName;
function creatReq(url,div) // 创建xmlhttprequest,ajax开始
{
divName=div;
if(window.XMLHttpRequest) //非IE浏览器,用xmlhttprequest对象创建
{
req=new XMLHttpRequest();
}
else if(window.ActiveXObject) //IE浏览器用activexobject对象创建
{
req=new ActiveXObject("Microsoft.XMLHttp");
}
if(req) //成功创建xmlhttprequest
{
req.open("Post",url,true); //与服务端建立连接(请求方式post或get,地址,true表示异步)
req.onreadystatechange = callback; //指定回调函数
req.send(null); //发送请求
}
}
function callback() //回调函数,对服务端的响应处理,监视response状态
{
if(req.readystate==4) //请求状态为4表示成功
{
if(req.status==200) //http状态200表示OK
{
Dispaly(); //所有状态成功,执行此函数,显示数据
}
else //http返回状态失败
{
alert("服务端返回状态" + req.statusText);
}
}
else //请求状态还没有成功,页面等待
{
document .getElementById (divName).innerHTML ="数据加载中";
}
}
function Dispaly() //接受服务端返回的数据,对其进行显示
{
document .getElementById (divName).innerHTML =req.responseText;
}
</script>
  回复  引用    

#7楼  2008-07-02 17:38 angel_tw [未注册用户]
在IE7和FF无反应
  回复  引用    

#8楼  2008-07-07 11:55 bit_kevin [未注册用户]
req.readystate 应该为 req.readyState ‘s’为大写。
  回复  引用    

#9楼  2008-07-14 16:31 xchbs [未注册用户]
相当的不错

  回复  引用    

#10楼  2008-07-19 22:12 FEIM Studios      
哈哈哈哈,好代码。
  回复  引用  查看    

#11楼  2008-08-26 14:22 phy [未注册用户]
@xudi
此人错误……
  回复  引用    


标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2007-04-15 09:37 编辑过


相关链接: