事件驱动编程:PHP的事件驱动问题讨论



看到有人在讨论PHP事件驱动问题本应回复但认为回复不足以引起大家重视故专开帖详述本人对这个问题理解并对佳作进行解释和分析

事件驱动这个概念是广义可以在客户端也可以在服务器端

在WEB应用上在客户端事件是基于JS或是插件或是JAVAAPPLET的类东西基本上如果是插件或是JAVAAPPLET就不属于HTML范畴了而真正必须用到JS场合其实并不多最多就是FORM提交或是链接点击的类基本操作因此谈论事件无太大意义

事件驱动真正意义并不在于可视化编程而在于它概念就象OO事件驱动其实是OO个延伸最初原型是消息机制但是事件驱动把消息封装成了个可有些类似于API中回调你自己可以定义这些执行内容而可视化编程则把这些独立出来定义好参数(多数是现成对象)让你自己写代码并运用这些参数(其实是用这些对象)做些事情

所以PHP有事件驱动是完全可能主要在于框架设计而要做成VB的类所谓可视化事件驱动则必须要有配套集成开发环境包括页面设计事件编码编译转码的类系列功能才行其实象点NET这样事件驱动只不过是把些常用WEB元素或Control控件如按钮、文本框的类东西封装了让你有个可视化界面可以设计当它编译的后仍然是<inputtype=\"text\">的类文本只是把你事件代码转为了JS或是服务器端代码而已而PHP主要是由于IDE不够丰富而且也没有预编译机制所以最后提交代码还是最终PHP代码而不是点NET资源代码和事件代码混合体(般是符合XML规范标准ASP文档包含了非标准HTML代码)故此PHP还无法达到大家心目中狭义所谓事件驱动编程但其实是完全可以没有问题

如果大家感兴趣不妨到www.php.net官方主页去看位中国哥们(QiangXue)写套基于事件驱动PHP框架PRADO这个还是获得高票当选最佳强烈推荐!你看了他源代码后就会理解PHP事件驱动是如何回事但我认为在这上面由于PHP无预编译机制而且过度依赖OO(虽然是用PHP5写代码)造成这个框架有些庞大且使用比较复杂可扩展性也不是很好不过其中理念非常的好有些想法还解决了困惑我多日问题我下面简单介绍下这个框架

该框架用ZDE及PHP5写成有详细文档结构十分清晰注释极为充分代码非常易于读懂介绍说明作者写码水平非常的高作者明确介绍说明这套框架参考了ASP点NET及BorlandDelphi概念

这个框架在验证性上非常的强(并不是指里面有什么验证登录的类模块)十分健壮几乎不可能有什么直接漏洞可以从外面攻入它是引入了规范标准文件这个概念做限制很有效地解决了大量验证时效率瓶颈这种验证思路方法只有个问题就是规范标准文件本身制作比较费力(当然用工具话是另回事了)然而旦做好(规范标准文件本身有格式和规范标准)验证就自然而然地由框架去做了而无需每次人为事件也可以定义在规范标准文件的内(我却认为这就没有必要了)其实它规范标准文件就有点类似于DELPHI或是VB中FORM定义文件只不过是用XML写纯文本而非可视化而对于事件驱动框架内置了套和点NET类似基本事件流你可以在区别阶段定制这些事件其实说白了就是重新定义这几个OnXXX用给定形式参数你也可以自己加入自己事件比如你在定义自己组件时在规范标准文件中定义好该组件可能有事件及参数以后你在使用该组件时可以直接定义这些被允许——不过我认为这种方式过于复杂且要大量读入并分析XML文件虽然十分地严谨很安全但有些过分了也没有充分利用到PHP本身灵活性思路是用类似于DELPHI句柄赋值办法或是用C回调特性即可在写代码时在任何时间任何地点定义事件而仍然能明确事件发出者及类型并有足够地安全性保证且无需机械地强制各个组件只能有哪些事件代码修改及扩展都十分方便当然在做大项目时候严格定义是必要不过即使如此该框架处理事件思路方法还是有些古板 [Page]

模板我认为是个比较好想法模板有些类似于点NETASP文件在编译前文件(我对ASP点NET并不熟但明白些原理)但起作用方式则类似于DELPHIFORM文件个很好概念缺点是用DW的类所见即所得通用编辑器则感觉不是很顺手个模板中可以同时把几个互斥组件放在而只在运行过程中决定显示哪些

就我本人看该框架代码还是发现它有些非常弱其中最主要个就是路径问题可扩展性很低应该比较适用于专用主机些受限主机(目录限制或是权限限制)就无能为力了也无相应提醒措施(也无相关接口)它对某些资源或文件路径用了种繁琐叫asService机制就是确定文件路径作者自己也说如果用了这个服务系统消耗会明显增加其实这个是借鉴了FLASH中aslibrary概念它这样虽然可以任意指定路径但每次都必须重新校验有些得不偿失作法则是固定好几个主要路径而其子目录都可随意就综合平衡了两者矛盾由于对路径问题缺乏考虑导致该框架对语言设置、个性化模板等无能为力如要翻译个项目手续的繁工作量的大是可想而知而且极易出错这是该框架中最严重个问题

从总体上来说该框架理念上设计上代码上绝对都属当然不足总是有不过完全不妨碍我们研究及学习它代码我并未全看只主要看了几个核心些介绍说明但已能足够看清楚其结构和思想对作者深表佩服但对其中不足也深表遗憾不管如何样它都绝对是研究PHP事件驱动代码好作品因此强烈推荐!

Tags:  事件驱动架构 事件驱动的特点 事件驱动 事件驱动编程

延伸阅读

最新评论

发表评论