Ajax,最近非常红火的技术。有很多现成的开发工具包。开始的时候我试用了CPAINT,支持php/asp,还不错。后来开始用perl的Ajax实现: CGI::Ajax。对比之下,发现非常好用。主要的特点是程序自动生成javascript调用的代码。这样的话,我们可以专注于程序逻辑的开发,而不用去理睬繁复的Ajax javascript调用。这是CGI::Ajax高明的地方。
CGI::Ajax安装
perl -MCPAN -e "install CGI::Ajax"
学习这个简单的例子
#!/usr/bin/perl -w use strict; use CGI::Ajax; use CGI;
下面是我们这个程序的核心逻辑部分。客户端通过会Ajax调用这个函数,得到想要的结果。
sub test_calculate { my ($cal1,$cal2)=@_; return ($cal1+$cal2); }
下面是客户端显示的html 注意onclick部分的写法。你可以将其理解为一段伪码(其实不是伪码,其实际代码部分都是CGI::Ajax自动生成的),表示调用函数calculate,参数是val1控件和val2控件的值,结果显示在result控件上。
sub Show_HTML { my $html = <<EOHTML; <HTML> <HEAD> <title>test</title> </HEAD> <BODY> <input type='text' name='val1' id='val1'> <input type='text' name='val2' id='val2'> <input type='button' name='cal' id='cal' value='cal it' onclick="calculate(['val1','val2'], ['result']);return true;"><br> <div id='result'></div> </BODY> </HTML> EOHTML return $html; } my $cgi=new CGI();
这里的代码将刚才提到的伪码calculate和我们的perl实现函数关联起来。这样,当客户端点击时调用calculate伪码,其效应就是程序自动生成的javascript代码就会启动Ajax机制,远程调用我们这个cgi中的test_calculate函数,并得到其结果,输出到相应的页面控件来显示。
my $ajax=new CGI::Ajax('calculate'=>/&test_calculate); #build_html
这一步中,CGI::Ajax会自动生成html网页和Ajax调用的所有javascript代码。而当客户端通过Ajax调用本程序时,这个build_html函数还会自动调用相应的函数(test_calculate)并且返回结果。
print $ajax->build_html($cgi,/&Show_HTML);
一个小问题
在页面的javascript中如果需要使用回车字符或者其他类似字符,那么必须要使用2个斜杠。
中文的问题
我以utf8为例。
1.页面字符集设定
使用下面的调用方式即可。
my @headers=("charset=utf8",); print $ajax->build_html($cgi,/&Show_HTML,/@headers);
2.返回结果集中文显示乱码
这是CGI::Ajax的小Bug。
解决办法如下:
找到你安装好的Ajax.pm,找到下面这句:
my $rv = $self->cgi()->header();
把它改成类似于这样的句子即可:
my $rv = $self->cgi()->header("charset=utf8");
当然,更好的办法是使用我们在
print $ajax->build_html($cgi,/&Show_HTML,/@headers);
相关文章
上一篇文章:AJAX及使用E4X编写Web服务脚本
下一篇文章:利用AJAX与数据岛实现无刷新绑定
- 推荐阅讯
- 实现基于 Ajax 的无限级菜单
- 巧用Ajax和RSS做个人门户网站
- BEA交付WebLogic 9.2,为实施SOA铺平道路
- AJAX应用解决一些常见问题
- RPG游戏设计快速入门之场景
- Eclipse 的历史、现状和未来
- Weblogic Portal中实现AJAX编程之架构
- JMX+J2SE5.0实现Web应用的安全管理
- 游戏编程入门之精灵ISprite
- Sun向更多PC厂商授权Java销售
- 阅读排行
- 1..net页面间的参数传递简单实例
- 2.VC++与Matlab混合编程之引擎操作详解
- 3.Oracle数据库数据对象分析
- 4.Eclipse3.2+Tomcat5.5.17+Oracle9配置
- 5.Oracle数据库中索引的维护
- 6.在Oracle的网络结构中解决连接问题
- 7.Oracle数据安全面面观
- 8.Oracle数据库的ORA-00257故障解决过程
- 9.Oracle数据库备份与恢复的三种方法
- 10.Oracle与SQL Server在企业应用中的比较
- 专题教程
- Windows Server-Windows Server文档-Windows Server新闻-Windows Ser PostgreSQL-PostgreSQL文档-PostgreSQL新闻-PostgreSQL专家
- WebLogic-WebLogic文档-WebLogic新闻-WebLogic专家 FreeBSD-FreeBSD文档-FreeBSD新闻-FreeBSD专家
- Linux-内核 GUI KDE Gnome DNS FTP 安全 安装-Linux专区 Windows-AD IIS ServerCore 虚拟化 安全 HPC-Windows专区
- 大话G游 专题:手机病毒揭密
- ARP攻击防范与解决方案 路由故障处理手册
