purity, etc." /> </pets> </data>
哇哦!看起来简单多了。让我们看看我们的processXML函数如何修改:
function processXML(obj){ var dataArray = obj.getElementsByTagName('pet'); var dataArrayLen = dataArray.length; var insertData = '<table><tr><th>' + 'Pets</th><th>Tasks</th></tr>'; for (var i=0; i<dataArrayLen; i++){ insertData += '<tr><td>' + dataArray[i].getAttribute('type') + '</td>' + '<td>' + dataArray[i].getAttribute('tasks') + '</td></tr>'; } insertData += '</table>'; document.getElementById ('dataArea').innerHTML = insertData; }
(Sheneyan注:修改后的示例见:example_2_4.html,XML文件见:data_2_4.xml)
就像你猜的一样,函数简单多了。因为代码变得简单,它也会变得更有效率。和我们比较老的函数的唯一的不同在于这个变量insertData现在插入更多的HTML,尤其是两个新变量“type”和“tasks”。就如我们较早之前所学的,那些属性是我们从XML文档的<pet>元素中取得的,而且每个pet的属性都有不同的值。对于你自己修改这个XML文件以适应你的进度的变动来说也许是最简单的方法。例如,如果你最终把你的猫身上的跳蚤抓光了,你只要简单从你的猫的每日任务表中把“减少跳蚤数量”删除,然而在之前我们使用的XML中,实现起来也许会觉得糊里糊涂。
最后的XML格式化的方法是将两部分混合。现在,我们将使用属性和不同的标签。让我们看一下示例XML:
<?xml version="1.0" encoding="UTF-8"?> <data> <pets> <猫 tasks="喂食, 饮水, 减少跳蚤数量" /> <狗 tasks="喂食, 饮水, 带出去遛遛" /> <鱼 tasks="喂食, 检查氧气,水的纯度,其它" /> </pets> </data>
这也许是最便于理解的XML。让我们分析一下我们为了让processXML函数运作起来所作的变更:
function processXML(obj){ var dataArray = obj.getElementsByTagName('pets')[0].childNodes; var dataArrayLen = dataArray.length; var insertData = '<table><tr><th>' + 'Pets</th><th>Tasks</th></tr>'; for (var i=0; i<dataArrayLen; i++){ if(dataArray[i].tagName){ insertData += '<tr><td>' + dataArray[i].tagName + '</td>' + '<td>' + dataArray[i].getAttribute('tasks') + '</td></tr>'; } } insertData += '</table>'; document.getElementById ('dataArea').innerHTML = insertData; }
(Sheneyan注:修改后的示例见:example_2_5.html,XML文件见:data_2_5.xml)
“dataArray”现在指向了<pets>的子节点,将它们作为一个数组对待(换句话说,dataArray现在是在<pets>节点内所有节点的数组)。这事因为每一个标签都不同(<猫 />,<狗 />,<鱼 />),所以我们不能使用这些元素的名称来搜索它们(而之前我们可以使用<pet>,因为所有的元素都是<pet>)。
还是一样,每个节点之间的有空格,所以在我们的处理过程中得排除掉文本节点。我们能够检验标签名是否存在-文本节点是节点但没有标签,而<猫 />,<狗 />,<鱼 />节点都是标签。所以如果一个标签有名字,那我们能够将数据插入变量insertData。我们插入的数据是一个表格并有两个表格数据格。这第一个单元格是标签名,也就是宠物的类型(猫,狗或鱼),而第二个单元格则是指定动物的“tasks”属性值(比如“喂食或饮水”)。
结束语
在这篇文章里,我演示了这个例子的很多变化,你可以随意试验它们来检验哪个更适合你。只要记住一点,XML是“可扩展的”,所以没有“错误的”方法来组合你的数据,虽然经常有一个“最好的”方法。而且,要注意让你的XML保持格式良好。记住很多问题来自于忘记结束一个标签(比如<狗 />而不是<狗>;除非这个节点中有数据,比如下面的<狗>这里有数据哦</狗>)。
我意图使XML和javascript的应用不糊涂而变得明朗。一步步的学习处理更多的数据,你能够将ajax运用于更大的用途。我希望看到ajax更多的应用于企业网站,及其它。所以如果你将这些知识应用于实践,我很高兴了解到你学到了什么(mail:jona#slightlyremarkable.com #换成@)。
在这个关于AJAX系列的第三部分中,我们将学习如何使用AJAX与服务端进行写作以及这些技术如何产生强大的web应用程序。如果你对学习如何构建类似GMail或者Google Maps的web程序感兴趣的话,这是一篇基础的入门(虽然那两个东东会比我们在这篇文章中提及的内容复杂的多)。在这篇文章中,我使用PHP作为服务端语言,但AJAX能够和任何服务端语言进行很好的兼容,所以你尽可以选择你所钟爱的任何语言!
我们还是从我们上一篇文章的代码(喏,就在上面)开始我们的学习,你可以去阅读它来作为参考。
这里就是这个HTML页面(带js):
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="zh-cn" dir="ltr"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <title>如何使用ajax开发web应用程序--示例</title> <script type="text/javascript"><!-- function ajaxRead(file){ var xmlObj = null; if(window.XMLHttpRequest){ xmlObj = new XMLHttpRequest(); } else if(window.ActiveXObject){ xmlObj = new ActiveXObject("Microsoft.XMLHTTP"); } else { return; } xmlObj.onreadystatechange = function(){ if(xmlObj.readyState == 4){ processXML(xmlObj.responseXML); } } xmlObj.open ('GET', file, true); xmlObj.send (''); } function processXML(obj){ var dataArray = obj.getElementsByTagName('pets')[0].childNodes; var dataArrayLen = dataArray.length; var insertData = '<table><tr><th>' + 'Pets</th><th>Tasks</th></tr>'; for (var i=0; i<dataArrayLen; i++){ if(dataArray[i].tagName){ insertData += '<tr><td>' + dataArray[i].tagName + '</td>' + '<td>' + dataArray[i].getAttribute('tasks') + '</td></tr>'; } } insertData += '</table>'; document.getElementById ('dataArea').innerHTML = insertData; } //--></script> <style type="text/css"><!-- table, tr, th, td { border: solid 1px #000; border-collapse: collapse; padding: 5px; } --></style> </head> <body> <h1>使用Ajax开发web应用程序</h1> <p>这个页面演示了AJAX技术如何通过动态读取一个远程文件来更新一个网页的内容--不需要任何网页的重新加载。注意:这个例子对于禁止js的用户来说没有效果。</p> <p>这个页面将演示如从取回并处理成组的XML数据。被取回的数据将会以表格形式输出到底下。 <a href="#" onclick="ajaxRead('data_3.php'); return false">查看演示</a>.</p> <div id="dataArea"></div> </body> </html>
(sheneyan注:示例见 example_3.html ) 注意:这里唯一的变化就是我们将我们的ajaxRead()中的“data_2.xml”改成了“data_3.php”。这是因为我们将使用php来输出XML(如果你在你的浏览器里打开这个PHP文件,它会以一个XML文件的形式展现出来--我们只是要在这个文件中进行操作而不只是一个简单的XML)。这个PHP文件的输出类似:
<?xml version="1.0" encoding="UTF-8"?> <data> <pets> <猫 tasks="喂食, 饮水, 抓跳蚤" /> <狗 tasks="喂食, 饮水, 带出去遛遛" /> <鱼 tasks="喂食, 检查氧气,水的纯度,其它" /> </pets> </data>
(Sheneyan注:示例就不提供了,参考底下说明即可。)
这只是输出结果,我们准备从一个mysql数据库中获取这些信息。从现在起,我们可以直接在我们的数据库中修改数据而不是手动修改XML文件。用AJAX通过PHP来取得数据,并将它获取到一个页面上--所有这些,仍然不需要重新加载网页。
第一步是连接到mysql去获取数据。这篇文章的重点在javascript,所以我不会解释下面的代码如何工作,你需要自己去了解如何连接mysql数据库。
<?php $user = "admin"; $pass = "adminpass"; $host = "localhost"; $conn = mysql_connect($host, $user, $pass) or die("Unable to connect to MySQL."); $db = mysql_select_db("pets",$conn) or die("Could not select the database."); mysql_close($db); ?>
只要你连接了数据库,你可以通过底下的查询来获取信息:
<?php $user = "admin"; $pass = "adminpass"; $host = "localhost"; $conn = mysql_connect($host, $user, $pass) or die("Unable to connect to MySQL."); $db = mysql_select_db("pets",$conn) or die("Could not select the database."); $result = mysql_query("SELECT * FROM `pets`"); if(mysql_num_rows ($result) == 0){ die ('Error: no data found in the database.'); } while ($row = mysql_fetch_assoc($result)){ echo 'Pet: '.$row['pet'].', tasks: '.$row['tasks'].'. '; } mysql_close($db); ?>
这段代码给了你需要的信息,但它输出并不正确。我们需要修改这PHP代码来分隔数据为XML,而不是纯文本。为了实现这个目标我们得作几个修改。
<?php header('Content-Type: text/xml');//编号1 echo '<?xml version="1.0" encoding="UTF-8"?>';//编号2 echo "\n<data>\n<pets>\n";//编号3 $user = "admin"; $pass = "adminpass"; $host = "localhost"; $conn = mysql_connect($host, $user, $pass) or die("无法连接mysql."); $db = mysql_select_db("pets",$conn) or die("无法选择数据库."); $result = mysql_query("SELECT * FROM `pets`"); if(mysql_num_rows ($result) == 0){ die ('Error: 数据库没有数据.'); } while ($row = mysql_fetch_assoc($result)){ echo '<'.$row['pet'].' tasks="'.$row['tasks'].'" />'."\n";//编号4 } echo "</pets>\n</data>";//编号5 mysql_close($db); ?>
让我们从上面开始,一次一行的来分析它是如何输出XML的.我给每一行都加了注释标记以便于更好的对应理解(原文是I've color-coded each line to make it easier to understand,我懒得上色,就改成用编号了)
编号1:这部分代码发送一个http头来让用户客户端明白这个php文件输出的是一个XML。这就是为什么你在你的浏览器里看这个文档的时候它以一个XML文件的形式展现,即使你的文件有一个“.php”后缀。
编号2:这部分的代码输出了XML声明。这是我之前展示给你看的XML的第一行。
编号3:这部分的代码输出的最开始的两个标签:我们的根标签,<data>和我们用来放置所有宠物的<pets>标签。
编号4:这部分的代码最困难的。这里包含了一个循环用来遍历你数据库里所有的数据。每次循环,它会输出一个新的节点,这个节点用每一种动物作为标签名以及一个"任务"属性。例如,如果你数据库中的第一只宠物是“猫”而且它相应的任务字段是“喂食, 饮水, 抓跳蚤”,那php将输出在XML文档中输出 <猫 tasks="喂食, 饮水, 抓跳蚤" /> 。这个“\n” 部分只是在结尾插入一个新行,保证这个XML代码不至于都在同一行。
编号5:这部分的代码结束了 我们开始时打开的</pets> 和 </data> 节点。因为XML必须是格式良好的(well-formed),所以我们必须认真对待这部分以 上一页 [1] [2] [3] [4] 下一页 [C语言系列]一个参数解决应用程序中WebBrowser的缓存问题 [平面设计]如何使用FireWorks制作沿路径排列的文字效果 [Web开发]网站应用程序池与运行时错误 [Web开发]vb6.exe - 应用程序错误的原因及解决办法 [网络技术]如何让应用程序和Socket等系统组件集成在一起 [网络技术]如何使用DOS命令有计划地重新启动IIS [电脑技术]图文解说如何使用QQ截图 [电脑技术]IE错误之应用程序发生异常unknown software excep… [聊天工具]Gmail推出新功能:Web Clip__天极Yesky [聊天工具]Web MSN你玩了吗__天极Yesky
|