如何使用ajax开发web应用程序(3)

如何使用ajax开发web应用程序(3)

  在这个关于AJAX系列的第三部分中,我们将学习如何使用AJAX与服务端进行写作以及这些技术如何产生强大的web应用程序。如果你对学习如何构建类似GMail外链或者Google Maps外链的web程序感兴趣的话,这是一篇基础的入门(虽然那两个东东会比我们在这篇文章中提及的内容复杂的多)。在这篇文章中,我使用PHP作为服务端语言,但AJAX能够和任何服务端语言进行很好的兼容,所以你尽可以选择你所钟爱的任何语言!

  我们还是从我们上一篇文章的代码开始我们的学习,你可以去阅读它来作为参考。

  这里就是这个HTML页面(带js):

Language:javascript, parsed in: 0.082 seconds, using GeSHi 1.0.7.12
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
  2.   "http://www.w3.org/TR/html4/strict.dtd">
  3. <html lang= "zh-cn" dir= "ltr">
  4.  <head>
  5.   <meta http-equiv= "Content-Type" content= "text/html; charset=utf-8">
  6.   <title>如何使用ajax开发web应用程序--示例</title>
  7.   <script type= "text/javascript"><!--
  8.   function ajaxRead (file ){
  9.     var xmlObj = null;
  10.     if (window. XMLHttpRequest ){
  11.       xmlObj = new XMLHttpRequest ();
  12.     } else if (window. ActiveXObject ){
  13.       xmlObj = new ActiveXObject ( "Microsoft.XMLHTTP" );
  14.     } else {
  15.       return;
  16.     }
  17.    xmlObj. onreadystatechange = function (){
  18.     if (xmlObj. readyState == 4 ){
  19.        processXML (xmlObj. responseXML );
  20.     }
  21.     }
  22.    xmlObj. open ( 'GET', file, true );
  23.    xmlObj. send ( '' );
  24.   }
  25.   function processXML (obj ){
  26.     var dataArray = obj. getElementsByTagName ( 'users' )[ 0 ]. childNodes;
  27.     var dataArrayLen = dataArray. length;
  28.     var insertData = '<table><tr><th>'
  29.     + 'Pets</th><th>Tasks</th></tr>';
  30.     for ( var i= 0; i<dataArrayLen; i++ ){
  31.       if (dataArray [i ]. tagName ){
  32.         insertData += '<tr><td>' + dataArray [i ]. tagName + '</td>'
  33.                    +  '<td>' + dataArray [i ]. getAttribute ( 'tasks' ) + '</td></tr>';
  34.       }
  35.     }
  36.    insertData += '</table>';
  37.    document. getElementById ( 'dataArea' ). innerHTML = insertData;
  38.   }
  39.   //--></script>
  40.   <style type= "text/css"><!--
  41.   table, tr, th, td {
  42.    border: solid 1px # 000;
  43.    border-collapse: collapse;
  44.    padding: 5px;
  45.   }
  46.   --></style>
  47.  </head>
  48.  <body>
  49.   <h1>使用Ajax开发web应用程序</h1>
  50.   <p>这个页面演示了AJAX技术如何通过动态读取一个远程文件来更新一个网页的内容--不需要任何网页的重新加载。注意:这个例子对于禁止js的用户来说没有效果。</p>
  51.   <p>这个页面将演示如从取回并处理成组的XML数据。被取回的数据将会以表格形式输出到底下。
  52.   <a href= "#" οnclick= "ajaxRead('data_3.php'); return false">查看演示< /a>.</p>
  53.   <div id= "dataArea"></div>
  54.  </body>
  55. </html>
  56.  

(sheneyan注:见示例外链)

  注意:这里唯一的变化就是我们将我们的ajaxRead()中的“data_2.xml”改成了“data_3.php”。这是因为我们将使用php来输出XML(如果你在你的浏览器里打开这个PHP文件,它会以一个XML文件的形式展现出来--我们只是要在这个文件中进行操作而不只是一个简单的XML)。这个PHP文件的输出类似:

Language:xml, parsed in: 0.015 seconds, using GeSHi 1.0.7.12
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <data>
  3.   <pets>
  4.     <tasks="喂食, 饮水, 抓跳蚤" />
  5.     <tasks="喂食, 饮水, 带出去遛遛" />
  6.     <tasks="喂食, 检查氧气,水的纯度,其它" />
  7.   </pets>
  8. </data> 
  9.  

(Sheneyan注:示例就不提供了,参考底下说明即可。)

  这只是输出结果,我们准备从一个mysql数据库中获取这些信息。从现在起,我们可以直接在我们的数据库中修改数据而不是手动修改XML文件。用AJAX通过PHP来取得数据,并将它获取到一个页面上--所有这些,仍然不需要重新加载网页。

  第一步是连接到mysql去获取数据。这篇文章的重点在javascript,所以我不会解释下面的代码如何工作,你需要自己去了解如何连接mysql数据库外链

Language:php, parsed in: 0.078 seconds, using GeSHi 1.0.7.12
  1. <?php
  2.   $user = "admin";
  3.   $pass = "adminpass";
  4.   $host = "localhost";
  5.   $conn = mysql_connect ( $host, $user, $pass ) or die ( "Unable to connect to MySQL." );
  6.   $db   = mysql_select_db ( "pets", $conn ) or die ( "Could not select the database." );
  7.   mysql_close ( $db );
  8. ?>
  9.  

  只要你连接了数据库,你可以通过底下的查询来获取信息:

Language:php, parsed in: 0.152 seconds, using GeSHi 1.0.7.12
  1. <?php
  2.   $user = "admin";
  3.   $pass = "adminpass";
  4.   $host = "localhost";
  5.   $conn = mysql_connect ( $host, $user, $pass ) or die ( "Unable to connect to MySQL." );
  6.   $db   = mysql_select_db ( "pets", $conn ) or die ( "Could not select the database." );
  7.   $result = mysql_query ( "SELECT * FROM `pets`" );
  8.   if ( mysql_num_rows ( $result ) == 0 ){
  9.       die ( 'Error: no data found in the database.' );
  10.   }
  11.   while ( $row = mysql_fetch_assoc ( $result )){
  12.       echo 'Pet: '. $row [ 'pet' ]. ', tasks: '. $row [ 'tasks' ]. '. ';
  13.   }
  14.  
  15.   mysql_close ( $db );
  16. ?>
  17.  

  这段代码给了你需要的信息,但它输出并不正确。我们需要修改这PHP代码来分隔数据为XML,而不是纯文本。为了实现这个目标我们得作几个修改。

Language:php, parsed in: 0.186 seconds, using GeSHi 1.0.7.12
  1. <?php
  2.   header ( 'Content-Type: text/xml' );
  3.   echo '<?xml version="1.0" encoding="UTF-8"?>';
  4.   echo "/n<data>/n<pets>/n";
  5.   $user = "admin";
  6.   $pass = "adminpass";
  7.   $host = "localhost";
  8.   $conn = mysql_connect ( $host, $user, $pass ) or die ( "无法连接mysql." );
  9.   $db   = mysql_select_db ( "pets", $conn ) or die ( "无法选择数据库." );
  10.   $result = mysql_query ( "SELECT * FROM `pets`" );
  11.   if ( mysql_num_rows ( $result ) == 0 ){
  12.       die ( 'Error: 数据库没有数据.' );
  13.   }
  14.   while ( $row = mysql_fetch_assoc ( $result )){
  15.       echo '<'. $row [ 'pet' ]. ' tasks="'. $row [ 'tasks' ]. '" />'. "/n";
  16.   }
  17.   echo "</pets>/n</data>";
  18.   mysql_close ( $db );
  19. ?>
  20.  

  让我们从上面开始,一次一行的来分析它是如何输出XML的.

行2:  这部分代码发送一个http头来让用户客户端明白这个php文件输出的是一个XML。这就是为什么你在你的浏览器里看这个文档的时候它以一个XML文件的形式展现,即使你的文件有一个“.php”后缀。

行3:  这部分的代码输出了XML声明。这是我之前展示给你看的XML的第一行。

行4:  这部分的代码输出的最开始的两个标签:我们的根标签,<data>和我们用来放置所有宠物的<pets>标签。

行15:  这部分的代码最困难的。这里包含了一个循环用来遍历你数据库里所有的数据。每次循环,它会输出一个新的节点,这个节点用每一种动物作为标签名以及一个"任务"属性。例如,如果你数据库中的第一只宠物是“猫”而且它相应的任务字段是“喂食, 饮水, 抓跳蚤”,那php将输出在XML文档中输出 <猫 tasks="喂食, 饮水, 抓跳蚤" /> 。这个“/n” 部分只是在结尾插入一个新行,保证这个XML代码不至于都在同一行。

行17:  这部分的代码结束了 我们开始时打开的</pets></data> 节点。因为XML必须是格式良好的(well-formed),所以我们必须认真对待这部分以确认我们的程序能够正确运行。

  现在我们已经让PHP输出XML了,我们现在所要作的就是登录我们的mysql数据库,并进行我们所需要的修改,来更新这个XML。很酷,不是吗?我们仍然能够使用上一篇文章中的js脚本来获取代码,因为XML输出和之前的完全一样。

结论

  你可以再进一步的扩展,使用XML来保存和获取数据。换句话说,你能够使用php来写你的XML文件,然后让javascript来读。用ajax,你也能够定时的检查xml文件是否已经更改而且,如果XML已经更新,也可以更新本页面。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值