django默认的模板功能还能够,可是不能直接用python的语法,mako解决了这个痛点,
使得django的模板变得像jsp同样,能够直接使用python的语法作一些事情。html
mako
django-mako
demopython
直接的相似python string format的样子git
from mako.template import Template mytemplate = Template("hello, ${name}!") print mytemplate.render(name="jack")
用文件github
from mako.template import Template mytemplate = Template(filename='/docs/mytmpl.txt', module_directory='/tmp/mako_modules') print mytemplate.render()
当template里面须要继承或者超找其余模板文件的时候,须要TemplateLookupdjango
from mako.template import Template from mako.lookup import TemplateLookup mylookup = TemplateLookup(directories=['/docs']) mytemplate = Template("""<%include file="header.txt"/> hello world!""", lookup=mylookup)
感受很复杂的样子,django-mako
的出现将这些繁琐的东西降至0,使django依然能够使用 render_to_response
jsp
一个简单的viewcode
``` from djangomako.shortcuts import render_to_response def index(request): return render_to_response('index.html', {}) ```
index.htmlorm
``` <%! import os %> <% rows = [[v for v in range(0,10)] for row in range(0,10)] %> <%def name="makerow(row)"> <tr> % for name in row: <td>${name}</td>\ % endfor </tr> </%def> <html> <body> ${os.path.sep} <table> % for row in rows: ${makerow(row)} % endfor </table> </body> </html> ```
之因此能这样调用都是由于django-mako有这么一个中间件,在settings.py中加入这个中间件就能够轻松的使用mako的语法了htm
``` from mako.lookup import TemplateLookup import tempfile class MakoMiddleware(object): def __init__(self): """Setup mako variables and lookup object""" from django.conf import settings # Set all mako variables based on django settings global template_dirs, output_encoding, module_directory, encoding_errors directories = getattr(settings, 'MAKO_TEMPLATE_DIRS', settings.TEMPLATE_DIRS) module_directory = getattr(settings, 'MAKO_MODULE_DIR', tempfile.mkdtemp()) output_encoding = getattr(settings, 'MAKO_OUTPUT_ENCODING', 'utf-8') encoding_errors = getattr(settings, 'MAKO_ENCODING_ERRORS', 'replace') global lookup lookup = TemplateLookup(directories=directories,. module_directory=module_directory, output_encoding=output_encoding,. encoding_errors=encoding_errors, ) import djangomako djangomako.lookup = lookup ```
文档中间件
注释
<%doc> these are comments more comments </%doc>
表达式
${表达式}: ${2*3} --> 6 ${pow(x,2) + pow(y,2)}
控制
% for a in ['one', 'two', 'three', 'four', 'five']: % if a[0] == 't': its two or three % elif a[0] == 'f': four/five % else: one % endif % endfor
代码块
与是不同的,只会载入一次,所以像定义方法,import东西的时候写在这里面
<%! import mylib import re def filter(text): return re.sub(r'^@', '', text) %> <% x = db.get_resource('foo') y = [z.element for z in x if x.frobnizzle==5] %>