::-- ZoomQuiet [DateTime(2005-12-11T04:50:15Z)] TableOfContents

1. K3日:发现!

Cheetah 只能组织有模板的页面输出,但是……

1.1. Karrigell_QuickForm

[http://www.orionlab.net/karrigell_quickform/Karrigell_QuickForm.html Karrigell_QuickForm] 真的是想要什么就来什么!

attachment:snap-KwDay30.png

1.1.1. 改造

毕竟是 alpha 版本,居然还是全面的table 结构!

1.1.2. 利用

直接将昨天的展示函式修改一下子就应该好用的!

   1 def qpubish(dict):
   2     exp = ""
   3     p = Karrigell_QuickForm('fm_kq','POST','#',dict.desc.desc)
   4     
   5     p.addElement('node','<ul>','')
   6     # 深入数据 基本和昨天的一样,仅仅是输出时使用 Karrigell_QuickForm 对象而已
   7     qli = {}
   8     k = [int(i) for i in dict.ask.keys()]
   9     k.sort()
  10     for i in k:
  11         ask = dict.ask[str(i)]
  12         qk = [j for j in ask.keys()]
  13         qk.sort()
  14         for q in qk:
  15             if 1==len(q):
  16                 qli[q] = ask[q]
  17             else:
  18                 pass        
  19         p.addRadioList("cr_ask%s"%i
  20                    ,ask["question"]
  21                    ,qli)
  22     p.addElement('node','</ul>','')
  23     p.addGroup(["submit","btn_submit","提交"]
  24                ,["reset","btn_reset","重写"])

1.2. JS 问题

一切顺心,表单正确生成了,但是,Karrigell_QuickForm 提供的JS检验不支持Radio列表的!

1.2.1. 继续发现!

现在的问题是有什么现成的可以模式化的定义表单测验的JS组件?

attachment:snap-KwDay30JVF.png

1.2.2. 迁就,先!

1.2.2.1. 关键代码

JVF的使用很有个性,使用外部的XML 文件进行设置,标准的J2EE行为哪!

1.2.3. 果然不出所料

仅仅追加少量代码就完成所想的客户端JS验证功能

def qpubish(dict):
    ...
    ## 具体问题解析
    k.sort()
    for i in k:
        ...
        p.addJSRule("cr_ask%s"%i,"问题%s "%i)
    ## 整体行为处理
    p.addJSValidation()
    p.saveJSRule("js/validation-config.xml")
    
    p.addElement('node','</ul>','')

1.3. 滥用Leo

到现在页面都是白丁!不能忍了!加载CSS!

1.3.1. CSS设计技巧

复用以前自个儿的积累是非常好的事儿!

attachment:snap-KwDay3color.png

1.3.2. CSS

attachment:snap-KwDay3css.png

1.4. 小节

今天发现并引入了 [http://www.orionlab.net/karrigell_quickform/Karrigell_QuickForm.html KQF]和 [http://www.amowa.net/jsvalidation/ JVF]好象有点复杂的样子…… attachment:snap-KwDay3done.png

1.5. 实例下载

使用 [wiki:self/AllAboutSubversion SVN 下载]:

  1. [wiki:selfsvn/zqlib/trunk/zqlib/tangle/zoomq/Karrigell/obpKWD/KwDay3/ KwDay3实例]

  2. 注意有在外部安置的 [wiki:selfsvn/zqlib/tangle/zoomq/Karrigell/obpKWD/js/ JS-JVF 目录]

1.6. 讨论

Include(/Discuss)


返回 KarrigellWebDev -- 快速体验K开发