本文实例讲述了flask框架自定义过滤器。分享给大家供大家参考,具体如下:
除了一些内置的join length safe等过滤器外, flask还提供了自定义过滤器的功能.
一. 自定义一个mardown过滤器
自定义一个markdown过滤器, 使过滤器可以像safe解析html标签一样解析md语法.
- 安装库
pip install Markdown==2.3.1
- 自定义过滤器
使用@app.template_filter(‘md')过滤器, 此时便拥有了名为md的过滤器.
@app.template_filter('md') def markdown_to_html(txt): from markdown import markdown return markdown(txt)
- 使用示例
views
@app.route('/', methods=['POST', 'GET']) def index(): return render_template('index.html', body='# hello')
- 模板中直接使用
{{ body|md|safe }}
二. 添加读取文件的功能
读取md文件, 并输出到html中
- 定义读文件函数
def read_md(filename): with open(filename) as md_file: content = reduce(lambda x, y: x+y, md_file.readline()) return content.decode('utf-8')
- 上下文管理器
此时read_md函数可以全局使用
@app.context_processor def inject_methods(): return dict(read_md=read_md)
- 可以在模板中调用函数
{{ read_md('test.md')|md|safe}}
希望本文所述对大家基于flask框架的Python程序设计有所帮助。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)