页面中加入标签。
2. 引入js。许多特效也可以通过javascript来进行处理,比如动态显示效果,或对元素进行封装。使用
它你需要在html页面加入
{{
htmlbuf }}
这里你可以看到htmlbuf,它是什么,它就是用来采集每个snippet类的类属性的。这里使用snippet对象加到htmlbuf中去。同时它还会将snippet的html代码在调用位置输出。
如何输出?首先uliweb的模板将转为python代码,它有一个内置的out对象,可以调用它的方法来输出
html代码。那么htmlbuf对象将在调用模板前被创建,在调用模板后被处理,在创建时将传入out的write
属性。这一切都是在simpleframe.py中通过plugin方法来实现的,但是这只是定义了一个调用点,如:
fname, code = template.render_file(filename, vars, env, dirs)
out = template.out()
template._prepare_run(vars, env, out)
callplugin(self, 'before_render_template', env, out)
if isinstance(code, (str, unicode)):
code = compile(code, fname, 'exec')
exec code in env, vars
text = out.getvalue()
output = execplugin(self, 'after_render_template', text, vars, env)
before_render_template 会在调用模板前被调用。after_render_template 会在调用模板后被调用。因
此你可以通过plugin机制来加入额外的处理。这是在settings.py中定义的,如:
@plugin('before_render_template')
def before_render_template(sender, env, out):
from uliweb.core import js
from uliweb.core.simpleframe import url_for
from uliweb.helpers import htmlwidgets
htmlbuf = js.htmlbuf(write=out.noescape, static_suffix=url_for('portal.views.static',
filename=''))
env['htmlbuf'] = htmlbuf
env['htmlwidgets'] = htmlwidgets
这里注入htmlbuf和htmlwidgets到模板的env环境中,所以可以在模板中直接使用。在htmlwidgets中已经
定义了一些snippet。htmlbuf在创建时,会使用out.noescape方法,它将不会对snippet中的代码进行转
义。static_suffix表示静态文件的前缀,缺省为/static/,这里由于使用了静态服务,所以通过url_for
来得到静态url前缀。
@plugin('after_render_template')
def after_render_template(sender, text, vars, env):
import re
r_links = re.compile(']|
