多年以来,创建真正具有响应性的 web 应用程序这一目标一直被 web 开发的一个简单事实所阻碍:要改变页面某一部分的信息,用户就必须重载整个页面。但是以后不再会这样了。感谢异步 java? 脚本和 xml(ajax),我们现在可以从服务器端请求新内容,只修改页面的一部分。这个教程解释了如何把 ajax 用于 php ,并介绍了简单 ajax 工具包(sajax),这是一个用 php 编写的工具,可以把服务器端 php 与 javascript 集成。
开始之前
这份教程针对的是对于开发富 web 应用程序感兴趣的人,富 web 应用程序把异步 javascript 和 xml(ajax)与 php 结合起来,用户每次点击时,不必刷新整个页面,就可以动态更新内容。这份教程假设读者了解基本的 php 概念,包括 if 和 switch 语句以及函数的使用。
关于本教程
在本教程中,将学习 ajax 以及围绕它的应用的问题。将用 php 构建一个 ajax 应用程序,显示以前写的一个教程中的面板。点击面板链接只会重新载入内容区,并用选定面板的内容替换它,从而节约了带宽和页面装入的时间。然后将把简单 ajax 工具包(sajax)集成进 ajax 应用程序,它可以同步 ajax 的使用,从而简化开发。
概述
在深入之前,先看看 ajax、示例 php 应用程序和 sajax。 ajax
ajax 允许 web 开发人员创建交互的 web 页面,同时避免必须等候页面载入这一瓶颈。通过 ajax 创建的应用程序,只需点击按钮,就可以用全新的内容替换 web 页面某一区域的内容。它的精彩之处在于不必等候页面装入,只有这一个区域的内容需要载入。以 google maps 为例:可以点击和四处移动地图,却不必等候页面载入。
ajax 的问题
在使用 ajax 时有些事需要注意。像其他 web 页面一样,ajax 页面是可以加书签的,所以在使用 get 与 post 进行请求时就会造成问题。国际化和编码方案数量的增加,使得把这些编码方案标准化变得日益重要。在这份教程中将了解这些重要的问题。
示例 php 应用程序
首先要用 ajax 创建一个应用程序,然后用 sajax 创建,以展现使用这个工具包的好处。应用程序是以前编写的教程中的一部分,带有面板链接。它被用作示例,以展示使用 ajax 的优势。因为在各个面板上点击时,它们会异步装入,而不必等候页面剩下的部分再次装入。这个示例应用程序还会展示如何创建自己的 ajax 应用程序。
sajax
如果想创建 ajax 应用程序,又不想受 ajax 复杂的细节所累。答案就是 sajax。通过使用 modernmethod 人员开发的库,sajax 为 web 开发人员抽象出了 ajax 的高层细节。在底层,sajax 的工作与 ajax 相同。但是,通过使用 sajax 库提供的高层函数,可以忽略 ajax 的技术细节。
什么是 ajax?
这一节是个入门介绍,用示例解释 ajax 的概念,包括在点击链接时发生了什么,ajax 用于 php 应用程序时需要的 html 和 javascript 代码。下一节将更深入一些,实际地使用在这一节学习的 ajax 概念创建 php 应用程序。
幕后内容
ajax 是异步 javascript 和 xml 的组合。之所以说异步,是因为可以点击页面上的链接,然后它只装入与点击对应的内容,同时保持标题或其他任何设定的信息不动。
点击链接时,在背后工作的是 javascript 函数。javascript 创建与 web 浏览器通信的对象,并告诉浏览器装入特定页面。然后可以像平常一样浏览同一页面上的其他内容,当浏览器完全装入新页面的时候,浏览器会在 html 的 div 标记指定的位置显示内容。
css 样式代码用来和 span 标记一起创建链接。
css 样式代码
示例应用程序需要 css 代码,这样 span 标记看起来就像使用常规的锚标记(<a href=... >)创建的真正链接一样,也会像真正的链接一样被点击。
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器