这部分内容虽然不多,但是看了好多天。
在 tgadmin 自动生成的 appname/appname/controller.py 中有如下代码:
Root.index 是 http://127.0.0.1:8080/index 的控制器。如果需要添加新的“页面”,只要在 Root 中添加新的方法即可:
17 def foobar(self):
18 return ‘Just another page‘
@expose() 是一定要加的,不加这个,无法定位控制器的方法。
我这里没有添加 template,所以框架将返回的内容直接作为字符串输出在页面上了。
如果想使用模板(默认为Kid),则指定模板名称 template=”appname.appname.foobar”,这个对应的是项目根开始的目录和模板文件名的结构。实际模板应保存在 appname/appname/foobar.kid 文件中。
控制器通过 expose 出来的方法的参数获得浏览器传递过来的变量,对上面的方法稍加改造即可:
17 def foobar(self, *args, **kv):
18 if (kv.has_key(‘name‘)):
19 name = kv[‘name‘]
20 else:
21 name = ‘unknown‘
22 return ‘Your name is ‘ + name
当访问 http://127.0.0.1:8080/foobar 时,页面显示 Your name is unknown。当访问 http://127.0.0.1:8080/foobar?name=fool 时,页面显示 Your name is fool。
当提供一个名为 default 的方法 expose 时,所有未定义的访问都会转到这个方法上去。这时,args 参数包含了访问所用的名字。例如访问 http://127.0.0.1:8080/barfoo,而 barfoo 未定义,那么default 方法被调用。同时 args[0] = “barfoo“。
好像控制器最基本的使用就这么些东西了,有点类似 Zend Framework 的 Controller->Action 的形式,仅仅是形式。