asfman
android developer
posts - 90,  comments - 213,  trackbacks - 0

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

作者: Jonathan Fenocchi

译者:Sheneyan(子乌)

时间:2005.11.22

英文原文:http://webreference.com/programming/javascript/jf/column14/index.html

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

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

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

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 dataArraydataArrayLen = 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   <href="#" onclick="ajaxRead('data_3.php'); return false">查看演示</a>.</p> 
53   <div id="dataArea"></div> 
54  </body> 
55 </ html >  
view plain | print | copy to clipboard | ?

(sheneyan注:见示例)

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

1 <? xml  version = "1.0"   encoding = "UTF-8" ?>  
2 < data >  
3   <pets> 
4     <猫 tasks="喂食, 饮水, 抓跳蚤" /> 
5     <狗 tasks="喂食, 饮水, 带出去遛遛" /> 
6     <鱼 tasks="喂食, 检查氧气,水的纯度,其它" /> 
7   </pets> 
8 </ data >     
view plain | print | copy to clipboard | ?

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

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

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

1 <?php  
2  $user = "admin";  
3  $pass = "adminpass";  
4  $host = "localhost";  
5  $conn = mysql_connect($host$user$passor die("Unable to connect to MySQL.");  
6  $db   = mysql_select_db("pets",$connor die("Could not select the database.");  
7  mysql_close($db);  
8 ?>  
view plain | print | copy to clipboard | ?

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

1 <?php  
2  $user = "admin";  
3  $pass = "adminpass";  
4  $host = "localhost";  
5  $conn = mysql_connect($host$user$passor die("Unable to connect to MySQL.");  
6  $db   = mysql_select_db("pets",$connor 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 ?>  
view plain | print | copy to clipboard | ?

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

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$passor die("无法连接mysql.");  
9  $db   = mysql_select_db("pets",$connor 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 ?>  
view plain | print | copy to clipboard | ?

  让我们从上面开始,一次一行的来分析它是如何输出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已经更新,也可以更新本页面。

关于作者

  Jonathan Fenocchi是一个网络开发者,主攻web设计,客户端脚本,php脚本。他的网站位于:http://www.slightlyremarkable.com

posted on 2006-03-22 09:41 汪杰 阅读(158) 评论(0)  编辑 收藏 引用
只有注册用户登录后才能发表评论。

<2024年3月>
252627282912
3456789
10111213141516
17181920212223
24252627282930
31123456

常用链接

留言簿(15)

随笔分类(1)

随笔档案(90)

文章分类(727)

文章档案(712)

相册

收藏夹

http://blog.csdn.net/prodigynonsense

友情链接

最新随笔

搜索

  •  

积分与排名

  • 积分 - 456687
  • 排名 - 6

最新随笔

最新评论

阅读排行榜

评论排行榜