设为首页收藏本站

Scripts 学盟

 找回密码
 加入学盟

QQ登录

只需一步,快速开始

查看: 4899|回复: 17
打印 上一主题 下一主题

Ajax基础入门   [复制链接]

Rank: 8Rank: 8

跳转到指定楼层
1#
momo 发表于 2011-4-10 00:30:14 |只看该作者 |正序浏览
因为搞那个新闻标题,遂向丫丫姐询问方法,丫丫姐说要ajax才可以实现,被逼无奈,只得来学这个东东,呵呵,还好以我这低等智力能看懂的,相信各位童鞋应该都能理解得了了 ,共享下今晚消化的基础部分

AJAX 的要点是 XMLHttpRequest 对象
不同的浏览器创建 XMLHttpRequest 对象的方法是有差异的。
IE 浏览器使用 ActiveXObject,而其他的浏览器使用名为 XMLHttpRequest 的 JavaScript 内建对象。

XMLHttpRequest 对象的三个重要的属性
onreadystatechange 属性存有处理服务器响应的函数。
readyState 属性存有服务器响应的状态信息。
这是 readyState 属性可能的值:
状态 描述
0 请求未初始化(在调用 open() 之前)
1 请求已提出(调用 send() 之前)
2 请求已发送(这里通常可以从响应得到内容头部)
3 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
4 请求已完成(可以访问服务器响应并使用它)
可以通过 responseText 属性来取回由服务器返回的数据

AJAX - 向服务器发送一个请求
要想把请求发送到服务器,我们就需要使用 open() 方法和 send() 方法。
open() 方法需要三个参数。第一个参数定义发送请求所使用的方法(GET 还是 POST)。第二个参数规定服务器端脚本的 URL。第三个方法规定应当对请求进行异步地处理。
send() 方法可将请求送往服务器


最后搭配个实例来消化下:
<html>
<head>
<script src="clienthint.js"></script>
</head>

<body>

<form>
First Name:<input type="text" id="txt1" onkeyup="showHint(this.value)" />
</form>

<p>Suggestions: <span id="txtHint"></span></p>

</body>
</html>
这是 JavaScript 代码,存储在文件 "clienthint.js" 中:

var xmlHttp

function showHint(str)
{

  if (str.length==0)
    {
    document.getElementById("txtHint").innerHTML="";
    return;
    }

  xmlHttp=GetXmlHttpObject()

  if (xmlHttp==null)
    {
    alert ("您的浏览器不支持AJAX!");
    return;
    }

  var url="gethint.asp";
  url=url+"?q="+str;
  url=url+"&sid="+Math.random();
  xmlHttp.onreadystatechange=stateChanged;
  xmlHttp.open("GET",url,true);
  xmlHttp.send(null);
}

function stateChanged()
{
if (xmlHttp.readyState==4)
{
document.getElementById("txtHint").innerHTML=xmlHttp.responseText;
}
}

function GetXmlHttpObject()
{
  var xmlHttp=null;
  try
    {
    // Firefox, Opera 8.0+, Safari
    xmlHttp=new XMLHttpRequest();
    }
  catch (e)
    {
    // Internet Explorer
    try
      {
      xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
      }
    catch (e)
      {
      xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
      }
    }
return xmlHttp;
}

AJAX ASP 实例
"gethint.asp" 页面中的代码针对 IIS 使用 VBScript 编写。它会检查一个名字数组,然后向客户端返回相应的名字:

<%
response.expires=-1
dim a(30)

'用名字为数组赋值
a(1)="Anna"
a(2)="Brittany"
a(3)="Cinderella"
a(4)="Diana"
a(5)="Eva"
a(6)="Fiona"
a(7)="Gunda"
a(8)="Hege"
a(9)="Inga"
a(10)="Johanna"
a(11)="Kitty"
a(12)="Linda"
a(13)="Nina"
a(14)="Ophelia"
a(15)="etunia"
a(16)="Amanda"
a(17)="Raquel"
a(18)="Cindy"
a(19)="Doris"
a(20)="Eve"
a(21)="Evita"
a(22)="Sunniva"
a(23)="Tove"
a(24)="Unni"
a(25)="Violet"
a(26)="Liza"
a(27)="Elizabeth"
a(28)="Ellen"
a(29)="Wenche"
a(30)="Vicky"

'从URL取得参数q
q=ucase(request.querystring("q"))

'如果q的长度大于0,则查找所有的hint
if len(q)>0 then
  hint=""
  for i=1 to 30
    if q=ucase(mid(a(i),1,len(q))) then
      if hint="" then
        hint=a(i)
      else
        hint=hint & " , " & a(i)
      end if
    end if
  next
end if

'如果找不到hint,则输出"no suggestion"
'或者输出正确的值
if hint="" then
  response.write("no suggestion")
else
  response.write(hint)
end if
%>
1

查看全部评分

分享到: QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
分享分享0 收藏收藏0
过了爱做梦的年纪
轰轰烈烈不如平静

管理员

超级大菜鸟

Rank: 9Rank: 9Rank: 9

18#
Alvin 实名认证  发表于 2011-4-17 20:24:41 |只看该作者
回复 12# momo


    为什么第三轮才是混混排前面

使用道具 举报

Rank: 8Rank: 8

17#
那个谁 发表于 2011-4-15 12:05:14 |只看该作者
回复 12# momo
   聪明的漠漠不会写个循环输出吗。。。{:3_51:}

使用道具 举报

Rank: 8Rank: 8

16#
momo 发表于 2011-4-15 11:36:18 |只看该作者
回复 14# 那个谁
杰杰是吧,哼哼。。。。。。。。。 臭杰杰
过了爱做梦的年纪
轰轰烈烈不如平静

使用道具 举报

Rank: 8Rank: 8

15#
那个谁 发表于 2011-4-15 10:46:31 |只看该作者
漠漠 强大弱智。。。

使用道具 举报

管理员

超级大菜鸟

Rank: 9Rank: 9Rank: 9

14#
Alvin 实名认证  发表于 2011-4-13 11:07:21 |只看该作者
回复 11# 莺子

身为美女管理员,快点上传头像,吸引游客加盟

使用道具 举报

Rank: 8Rank: 8

13#
momo 发表于 2011-4-13 09:43:05 |只看该作者
回复 11# 莺子
谢谢丫丫姐,谢谢混混,谢谢燕姐
谢谢燕姐,谢谢丫丫姐,谢谢混混
谢谢混混,谢谢燕姐,谢谢丫丫姐
‘’‘’‘’‘’‘’‘’‘’‘’‘’
......................................................
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
-------------------------------------------

好多的组合啊,写不过来啊,每个人都在前一次每个人都最后一次,哇咔咔我好聪明!!!
过了爱做梦的年纪
轰轰烈烈不如平静

使用道具 举报

Rank: 9Rank: 9Rank: 9

12#
莺子 发表于 2011-4-13 08:58:31 |只看该作者
为什么我的名字在最后一个

使用道具 举报

管理员

超级大菜鸟

Rank: 9Rank: 9Rank: 9

11#
Alvin 实名认证  发表于 2011-4-12 16:58:50 |只看该作者

爆了个客户端错误
这小姑娘对着服务端代码,找了一整天

使用道具 举报

Rank: 8Rank: 8

10#
momo 发表于 2011-4-12 16:47:13 |只看该作者
回复 8# 丫丫
搞定了,谢谢丫丫姐,谢谢混混,谢谢燕姐
过了爱做梦的年纪
轰轰烈烈不如平静

使用道具 举报

您需要登录后才可以回帖 登录 | 加入学盟

手机版|Scripts 学盟   |

GMT+8, 2024-12-19 07:49 , Processed in 1.107600 second(s), 14 queries .

Powered by Discuz! X2

© 2001-2011 Comsenz Inc.

回顶部