最近在做畅言网改版,基本上把畅言网从里到外摸了遍,谈下最近开发下来的感想。
畅言网是基于开源的radiant cms系统上的二次开发,github上能搜到源码,有兴趣的可以看下。
radiant cms系统主要用到gem是radius gem,这个系统基本上是对这个gem的二次封装,通过更简单的方式来自定义tag,在html中使用这些tag,通过Radius::Parser就可以将这些tag转换成html(radius gem的具体的用法也可以在github上搜到)。
说道使用tag这个功能我就忍不住要吐槽下了,radiant cms使用这个功能的原先的目的是使用者可以利用这些tag来定义动态的网页,但是真正的使用者有多少是懂后台的,对于开发者来讲这些tag很简单,但是对于使用者来理解这些tag就有了很大的难度。所以畅言网上这个功能的就是开发者来使用了。
那么问题来了,这个功能对于开发者来讲就如同鸡肋一样。畅言网改版需要改大概10个页面,使用tag来构建这些页面我需要写10个页面的代码,每个页面每个模块都需要分别测试,尤其是测试很麻烦,加大很多工作量。虽然页面功能类似的我可以复制黏贴,但是一旦改个需求我所有复制黏贴的代码都必须改动,这是相当痛苦的。如果这个系统使用的是ruby写的模板的话,可能这些问题都可以得到很好的解决,代码量至少可以减少7倍左右,开发效率也会变高,代码也容易维护很多。可是在现有系统架构上单单使用模板的话,还是会有这样那样的问题。
所以做完畅言网改版后我就想说可不可以将这两者结合,就是使用tag来加载模板。思路基本上都想好了需要点时间测试这块代码,如果能够实现这个功能的话,系统在代码量上还有维护性上都会有很大的提高。
最近畅言网改版改的心好累,rails这速度慢的真让人抓狂。。。