转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
如何使用Ajax技术开发Web应用程序(3)         ★★★★

如何使用Ajax技术开发Web应用程序(3)

作者:闵涛 文章来源:闵涛的学习笔记 点击数:594 更新时间:2009/4/23 11:29:47

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

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

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

!DOCTYPE html PUBLIC -W3CDTD HTML 4.01EN
 httpwww.w3.orgTRhtml4strict.dtd
html lang=zh-cn dir=ltr
 head
  meta http-equiv=Content-Type content=texthtml; charset=iso-8859-1
  title如何使用ajax开发web应用程序--示例title
  script type=textjavascript!--
  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 = 'tabletrth'
    + 'PetsththTasksthtr';
   for (var i=0; idataArrayLen; i++){
     if(dataArray[i].tagName){
        insertData += 'trtd' + dataArray[i].tagName + 'td'
                   +  'td' + dataArray[i].getAttribute('tasks') + 'tdtr';
     }
   }
   insertData += 'table';
   document.getElementById ('dataArea').innerHTML = insertData;
  }
  --script
  style type=textcss!--
  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=dataAreadiv
 body
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 textxml');编号1
 echo 'xml version=1.0 encoding=UTF-8';编号2
 echo ndatanpetsn;编号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 petsndata;编号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),所以我们必须认真对待这部分以确认我们的程序能够正确运行。

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

  结论

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

 
 
 
作者:Sheneyan    

 


没有相关教程
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台