Chinaunix首页 | 论坛 | 博客
  • 博客访问: 416982
  • 博文数量: 48
  • 博客积分: 1032
  • 博客等级: 上士
  • 技术积分: 1256
  • 用 户 组: 普通用户
  • 注册时间: 2012-05-19 13:24
文章分类

全部博文(48)

文章存档

2014年(3)

2013年(23)

2012年(22)

分类: 系统运维

2012-12-11 16:31:22

在w3school上面看到一个关于异步传输的例子,在服务器端其用asp和php两种方式实现了该传输,在这里我将服务器端程序改装一下使用ejs完成相同功能。
    说到web异步传输不得不提到XMLHttpRequest对象,它是所有异步传输的基础。如:ajax;XMLHttpRequest用于在后台与服务器交换数据。
主要的功能:
   1、在不重新加载页面的情况下更新网页;
   2、在页面已加载后从服务器请求数据;
   3、在页面已加载后从服务器接收数据;
   4、在后台向服务器发送数据;
创建方式:

  1. var xmlhttp;
  2. if (window.XMLHttpRequest)
  3.   {// code for IE7+, Firefox, Chrome, Opera, Safari
  4.   xmlhttp=new XMLHttpRequest();
  5.   }
  6. else
  7.   {// code for IE6, IE5
  8.   xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  9.   }
发送请求:

  1. open(method,url,async) 规定请求的类型、URL 以及是否异步处理请求
参数:
1、method:请求的类型;GET或者POST;
2、url:文件在服务器上的位置;
3、async:true(异步)或者false(同步)

  1. send(string) 将请求发送到服务器。
参数string:用于POST请求;

服务器端响应:

  1. responseText 获得字符串形式的响应数据。
  2. respon***ML 获得 XML 形式的响应数据。
onreadystatechange事件:
当请求发送到服务器的时候,就会去响应一下任务。
每当 readyState 改变时,就会触发 onreadystatechange 事件。

点击(此处)折叠或打开

  1. onreadystatechange     存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。

  2. readyState    存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
  3. 0: 请求未初始化
  4. 1: 服务器连接已建立
  5. 2: 请求已接收
  6. 3: 请求处理中
  7. 4: 请求已完成,且响应已就绪

  8. status     200: "OK"
  9. 404: 未找到页面
当 readyState 等于 4 且状态为 200 时,表示响应已就绪;eg:

  1. xmlhttp.onreadystatechange=function()
  2.   {
  3.   if (xmlhttp.readyState==4 && xmlhttp.status==200)
  4.     {
  5.     document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
  6.     }
  7.   }
上面就是整个XMLHttpRequest响应过程,下面是例子;客户端代码不变,只改动服务器端代码。

服务器端:

  1. <html>
  2. <body>
  3. <%
  4.     var a = new Array(30);
  5.     a[1]="Anna";
  6.     a[2]="Brittany";
  7.     a[3]="Cinderella";
  8.     a[4]="Diana";
  9.     a[5]="Eva";
  10.     a[6]="Fiona";
  11.     a[7]="Gunda";
  12.     a[8]="Hege";
  13.     a[9]="Inga";
  14.     a[10]="Johanna";
  15.     a[11]="Kitty";
  16.     a[12]="Linda";
  17.     a[13]="Nina";
  18.     a[14]="Ophelia";
  19.     a[15]="Petunia";
  20.     a[16]="Amanda";
  21.     a[17]="Raquel";
  22.     a[18]="Cindy";
  23.     a[19]="Doris";
  24.     a[20]="Eve";
  25.     a[21]="Evita";
  26.     a[22]="Sunniva";
  27.     a[23]="Tove";
  28.     a[24]="Unni";
  29.     a[25]="Violet";
  30.     a[26]="Liza";
  31.     a[27]="Elizabeth";
  32.     a[28]="Ellen";
  33.     a[29]="Wenche";

  34.     var value,result;
  35.     value = params.q;//接收表单数据
  36.     var i,s,s1="";
  37.     if (value != null)
  38.         {
  39.         result = ""
  40.         for (i = 1;i < 30; i++){
  41.         s = a[i].substring(0,1);
  42.         if (s == value){
  43.             if (result == ""){
  44.             result = a[i];
  45.             }
  46.             else {
  47.             result = result +','+a[i];
  48.             }
  49.             }
  50.         }
  51.         }
  52.         if (result == ""){
  53.             write("no suggestion");
  54.         }
  55.         else{
  56.             write(result);
  57.         }

  58. %>
  59. </body>
  60. </html>
客户端代码:

  1. <html>
  2. <head>
  3. <script type="text/javascript">
  4. function showHint(str)
  5. {
  6. var xmlhttp;
  7. if (str.length==0)
  8.   {
  9.   document.getElementById("txtHint").innerHTML="";
  10.   return;
  11.   }
  12. if (window.XMLHttpRequest)
  13.   {// code for IE7+, Firefox, Chrome, Opera, Safari
  14.   xmlhttp=new XMLHttpRequest();//创建XMLHttpRequest对象
  15.   }
  16. else
  17.   {// code for IE6, IE5
  18.   xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");//老的浏览器所指出的XMLHttpRequest对象
  19.   }
  20. xmlhttp.onreadystatechange=function()
  21.   {
  22.   if (xmlhttp.readyState==4 && xmlhttp.status==200) //判断响应是否接受完成
  23.     {
  24.     document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
  25.     }
  26.   }
  27. xmlhttp.open("GET","xml.ejs?q="+str,true);//请求格式
  28. xmlhttp.send();//发送请求
  29. }
  30. </script>
  31. </head>
  32. <body>

  33. <h3>请在下面的输入框中键入大写字母(A - Z):</h3>
  34. <form action="">
  35. 姓氏:<input type="text" id="txt1" onkeyup="showHint(this.value)" />
  36. </form>
  37. <p>建议:<span id="txtHint"></span></p>

  38. </body>
  39. </html>
通过这个例子我们可以知道在服务器端选择ejs的优势,它可以让开发者在开发客户端界面和服务器端程序时使用相同的编程语言。ejs只是js的一个模板补充。






阅读(2810) | 评论(1) | 转发(0) |
0

上一篇:EJScript数据交互

下一篇:jQuery创建滑动条

给主人留下些什么吧!~~

CCAbyss2014-12-09 11:34:06

楼主你好!我用你的代码跑了一下,浏览器报错500,应该是我EJS配置的问题,EJS默认访问index.ejs,我想请教一下怎样才能修改他的默认路径来访问我的自定义ejs文件呢?比如xml.ejs。我现在用
appweb  --home /etc/appweb/ --ejs /xml.ejs:/etc/appweb/blog/ --log stdout:4让它遇到xml.ejs就自动访问index.ejs,但是实际运行的时候还是会报错(500),想请教有什么办法解决这个问题?