dwarson的专栏

子在川上曰:逝者如斯夫!不舍昼夜。

用户操作
[即时聊天] [发私信] [加为好友]
吴俊ID:dwarson
21454次访问,排名5847,好友0人,关注者0人。
dwarson的文章
原创 46 篇
翻译 0 篇
转载 14 篇
评论 24 篇
dwarson的公告
朋友的blog
小妹木兰
龙哥
12的blog
有事留言

音乐

欢迎光临我的博客!

《Me in You You in me》

(假如爱有天意)

Neo Ei Gei Nan Hae Jil Neok No Ul Cheo Reom Han Pyeo Nui A Lum Da Wun Chu Eo Ki Doe Go So Zhong Hae Deon Wu Li Pu Re Deon Na Lul Gi Eo Ka Myeo Wu~Hu Hui Eob Si Ge Lim Cheo Reom Na Ma Ju Gi Rul Na Ei Gei Nan Nae Woe Lob Deon Ji Nan Si Ga Lel Hwa Na Gei Bi Chon Ju Deon Hae Sa Li Dui Go Jo Ge Ma Deon Neo Ui Ha Yan Son Wi Ei Bi Na Nen Bo Seok Cheo Reom Young Wo Nui Yak So Ki Dui Eo Neo Ei Gei Nan Hae Jil Neok No Ul Cheo Reom Han Pyeo Nui A Lum Da Wun Chu Eo Ki Doe Go So Zhong Hae Deon Wu Li Pu Re Deon Na Lul Gi Eo Ka Myeo Wu~Hu Hui Eob Si Ge Lim Cheo Reom Na Ma Ju Gi Rul


日历

YearMonth [Next] [Prev]

北京时间

最近评论
june.wu:谢谢小妹的留言,感动ing,小妹很优秀,希望你工作顺利啊~吼吼。
木兰:小弟~~
看了你的文字,偶更加惭愧.偶大二时,写过asp网上投票系统,写过最多的代码是一cpp文件,1000来行,之后,再也没写过code.大三,学了Java,知道了JDBC怎么连接,考试over了,就再也没写过java代码了,大四,我才学unix,为的是考试,后来用了ret hat linux之后,才知道BSD,然后再知道开源是什么,然后知道国防科大开发的一OS,再然后得知一叫Da……
木兰:A ZA A ZA FIGHTING!
tombaby:
文章分类
收藏
相册
去年今日
工作
婚姻和爱需要学习 (RSS)
35岁之前成功12条黄金法则(RSS)
Java面试笔试题大汇总 及c/c++面试试题转载 (RSS)
Tomcat5.5.x配置整理(RSS)
一位师兄找工作的历程 (RSS)
一位软件工程师的软件过程总结(RSS)
世界500强面试题目及评点(RSS)
你适合区外企么?(RSS)
写给找工作的朋友们 (RSS)
应聘Java笔试时可能出现问题及其答案 (RSS)
当今大学生创业的冷门路线
我在为谁而工作 (RSS)
深圳求职指南(2004版)(RSS)
深夜发原创,新公司一年总结
程序员每天该做的事
程序员网站资源宝库 (RSS)
赴微软面试的朋友请高度注意(RSS)
赴微软面试的朋友请高度注意(RSS)
面试技巧(RSS)
技术文章
掌握 Ajax,第 3 部分: Ajax 中的高级请求和响应
用Acegi为你的Spring应用加把锁! (RSS)
编写你自己的单点登录(SSO)服务 (RSS)
Appfuse总结(RSS)
Asp.net页面的生命周期(RSS)
ASP被人注入(RSS)
EJB调用的原理分析 (RSS)
HTTP/1.1 500 Internal Server Error(RSS)
Java5.0,越来越死板的java (RSS)
java中的事件机制
Java学习从入门到精通(RSS)
JBPM
JDK1.4下实现访问WIN32注册表 (RSS)
Polestar的大学十年之博士生活导读(RSS)
tomcat中的server.xml元素详解 (RSS)
Tomcat启动分析 (RSS)
Web报表工具iReport 1.2.2 详解 (RSS)
两个数组的整数乘法(RSS)
中国人为何勤劳却不富有(RSS)
任正非千金买马骨:与李一男戏剧性恩怨情仇
如何判断字串里逗号的个数(RSS)
学编程,决不可心浮气燥
开发web应用难于上青天,web开发十八难 (RSS)
开源企业软件采购指南(转载)(RSS)
怎么理解函数的返回值(RSS)
我在华为打工的日子 (RSS)
我的地图(RSS)
深入研究Asp.net页面的生命周期(RSS)
深圳、香港、新加坡 我的程序轨迹
牛人1,偶像(RSS)
纵论5-7年内的技术发展大势 (Robbin) (RSS)
编码人员和美工的配合问题 (RSS)
面向对象:你入门了吗?
面试遇到的C语言难题(RSS)
考研
2005年政治考研大纲任汝芬解析[音频]
生活&家庭
一个成熟恋情必须经过四个阶段
男人可以为女人做的50件事 (RSS)
学习方法
18条人生宝贵经验 (RSS)
如何才能去做喜欢的事情(RSS)
高效管理考研时间的黄金法则
黄维仁——迷恋和爱情的区别 (RSS)
存档
软件项目交易
订阅我的博客
XML聚合  FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
订阅到BlogLines
订阅到Yahoo
订阅到GouGou
订阅到飞鸽
订阅到Rojo
订阅到newsgator
订阅到netvibes

转载 AJAX基础教程(转贴)收藏

新一篇: 螺旋式上升的领军人宫力  | 旧一篇: 过得好快

什么是 AJAX?

  AJAX (异步 JavaScript 和 XML) 是个新产生的术语,专为描述JavaScript的两项强大性能.这两项性

能在多年来一直被网络开发者所忽略,直到最近Gmail, Google suggest和google Maps的横空出世才使人

们开始意识到其重要性.

  这两项被忽视的性能是:

    * 无需重新装载整个页面便能向服务器发送请求.
    * 对XML文档的解析和处理.

  步骤 1 – "请!" --- 如何发送一个HTTP请求

  为了用JavaScript向服务器发送一个HTTP请求, 需要一个具备这种功能的类实例.

这样的类首先由Internet Explorer以ActiveX对象引入, 被称为XMLHTTP. 后来Mozilla, Safari 和其他

浏览器纷纷仿效, 提供了XMLHttpRequest类,它支持微软的ActiveX对象所提供的方法和属性.

  因此, 为了创建一个跨浏览器的这样的类实例(对象), 可以应用如下代码:

if (window.XMLHttpRequest) { // Mozilla, Safari, ...
    http_request = new XMLHttpRequest();
} else if (window.ActiveXObject) { // IE
    http_request = new ActiveXObject("Microsoft.XMLHTTP");
}

  (上例对代码做了一定简化,这是为了解释如何创建XMLHTTP类实例.

实际的代码实例可参阅本篇步骤3.)

  如果服务器的响应没有XML mime-type header,某些Mozilla浏览器可能无法正常工作. 为了解决这个

问题, 如果服务器响应的header不是text/xml,可以调用其它方法修改该header.

http_request = new XMLHttpRequest();
http_request.overrideMimeType('text/xml');

  接下来要决定当收到服务器的响应后,需要做什么.这需要告诉HTTP请求对象用哪一个JavaScript函数

处理这个响应.可以将对象的onreadystatechange属性设置为要使用的JavaScript的函数名,如下所示:

http_request.onreadystatechange = nameOfTheFunction;

  注意:在函数名后没有括号,也无需传递参数.另外还有一种方法,可以在扉页(fly)中定义函数及其对

响应要采取的行为,如下所示:

http_request.onreadystatechange = function(){
    // do the thing
};

  在定义了如何处理响应后,就要发送请求了.可以调用HTTP请求类的open()和send()方法, 如下所示:

http_request.open('GET', 'http://www.example.org/some.file', true);
http_request.send(null);

    * open()的第一个参数是HTTP请求方式 – GET, POST, HEAD 或任何服务器所支持的您想调用的方式

. 按照HTTP规范,该参数要大写;否则,某些浏览器(如Firefox)可能无法处理请求.有关HTTP请求方法的详

细信息可参考http://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html W3C specs
    * 第二个参数是请求页面的URL.由于自身安全特性的限制,该页面不能为第三方域名的页面.同时一定

要保证在所有的页面中都使用准确的域名,否则调用open()会得到"permission denied"的错误提示.一个

常见的错误是访问站点时使用domain.tld,而当请求页面时,却使用www.domain.tld.
    * 第三个参数设置请求是否为异步模式.如果是TRUE, JavaScript函数将继续执行,而不等待服务器响

应.这就是"AJAX"中的"A".

  如果第一个参数是"POST",send()方法的参数可以是任何想送给服务器的数据. 这时数据要以字符串

的形式送给服务器,如下所示:

name=value&anothername=othervalue&so=on

  步骤 2 – "收到!" --- 处理服务器的响应

  当发送请求时,要提供指定处理响应的JavaScript函数名.

http_request.onreadystatechange = nameOfTheFunction;

  我们来看看这个函数的功能是什么.首先函数会检查请求的状态.如果状态值是4,就意味着一个完整的

服务器响应已经收到了,您将可以处理该响应.

if (http_request.readyState == 4) {
    // everything is good, the response is received
} else {
    // still not ready
}

  readyState的取值如下:

    * 0 (未初始化)
    * 1 (正在装载)
    * 2 (装载完毕)
    * 3 (交互中)
    * 4 (完成)

(Source)

  接着,函数会检查HTTP服务器响应的状态值. 完整的状态取值可参见 W3C site. 我们着重看值为200

OK的响应.

if (http_request.status == 200) {
    // perfect!
} else {
    // there was a problem with the request,
    // for example the response may be a 404 (Not Found)
    // or 500 (Internal Server Error) response codes
}

  在检查完请求的状态值和响应的HTTP状态值后, 您就可以处理从服务器得到的数据了.有两种方式可

以得到这些数据:

    * http_request.responseText – 以文本字符串的方式返回服务器的响应
    * http_request.responseXML –

以XMLDocument对象方式返回响应.处理XMLDocument对象可以用JavaScript DOM函数

  步骤 3 – "万事俱备!" - 简单实例

  我们现在将整个过程完整地做一次,发送一个简单的HTTP请求. 我们用JavaScript请求一个HTML文件,

test.html, 文件的文本内容为"I'm a test.".然后我们"alert()"test.html文件的内容.

<script type="text/javascript" language="javascript">

    var http_request = false;

    function makeRequest(url) {

        http_request = false;

        if (window.XMLHttpRequest) { // Mozilla, Safari,...
            http_request = new XMLHttpRequest();
            if (http_request.overrideMimeType) {
                http_request.overrideMimeType('text/xml');
            }
        } else if (window.ActiveXObject) { // IE
            try {
                http_request = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {
                try {
                    http_request = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e) {}
            }
        }

        if (!http_request) {
            alert('Giving up :( Cannot create an XMLHTTP instance');
            return false;
        }
        http_request.onreadystatechange = alertContents;
        http_request.open('GET', url, true);
        http_request.send(null);

    }

    function alertContents() {

        if (http_request.readyState == 4) {
            if (http_request.status == 200) {
                alert(http_request.responseText);
            } else {
                alert('There was a problem with the request.');
            }
        }

    }
</script>
<span
    style="cursor: pointer; text-decoration: underline"
    onclick="makeRequest('test.html')">
        Make a request
</span>

  本例中:

    * 用户点击浏览器上的"请求"链接;
    * 接着函数makeRequest()将被调用.其参数 – HTML文件test.html在同一目录下;
    * 这样就发起了一个请求.onreadystatechange的执行结果会被传送给alertContents();
    * alertContents()将检查服务器的响应是否成功地收到,如果是,就会"alert()"test.html文件的内

容.

  步骤 4 – "X-文档" --- 处理XML响应

  在前面的例子中,当服务器对HTTP请求的响应被收到后,我们会调用请求对象的reponseText属性.该属

性包含了test.html文件的内容.现在我们来试试responseXML属性.

  首先,我们新建一个有效的XML文件,后面我们将使用这个文件.该文件(test.xml)源代码如下所示:

<?xml version="1.0" ?>
<root>
    I'm a test.
</root>

  在该脚本中,我们只需修改请求部分:

...
onclick="makeRequest('test.xml')">
...

  接着,在alertContents()中,我们将alert()的代码alert(http_request.responseText);换成:

var xmldoc = http_request.responseXML;
var root_node = xmldoc.getElementsByTagName('root').item(0);
alert(root_node.firstChild.data);

  这里,我们使用了responseXML提供的XMLDocument对象并用DOM方法获取存于XML文件中的内容.

发表于 @ 2006年02月19日 22:38:00|评论(loading...)|编辑

新一篇: 螺旋式上升的领军人宫力  | 旧一篇: 过得好快

评论

#tombaby 发表于2006-02-22 09:47:00  IP: 203.156.238.*

发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © dwarson