2019-06-03Flask第二集

Flask框架第二集 Flask-Bootstrap集成Twitter Bootstrap Bootstrap是客户端框架,因此不会直接涉及服务器。服务器需要做的只是提供引用了BootstrapCSS和JS文件的HTML响应,并在HTML、CSS和JS代码中实例化所需组建。

初始化Flask-Bootstrap

from flask.ext.bootstrap import Bootstrap #... bootstrap=Bootstrap(app)

【2019-06-03Flask第二集】user.html改写为衍生模板后的新版本:
templates/user.html:使用Flask-Bootstrap的模板
{% extends "bootstrap/base.html" %}{% block title %}Flasky{% endblcok %}{% block navbar %} Flasky {% endblock %}{% block content %}Hello, {{ name }}!{% endblock %}

Bootstrap官方文档(http://getbootstrap.com/)有很多好的示例。
自定义错误界面
@app.errorhandler(404) def page_nat_found(e): return render_template('404.html'),404@app.errorhandler(500) def internal_server_error(e): return render_template('500.html'),500

Flask-Bootstrap提供了一个具有压面基本布局的基模板,同样,程序可以定义一个具有更完整页面布局的基模板。


templates/user.html:使用模板继承机制简化页面模板
{% extends "base.html" %}{% block title %}Flasky{% endblock %}{% block page_content %}Hello,{{ name }}!{% endblcok %}

链接 对于包含可变部分的动态路由,在模板中构建正确的URL就很困难,Flask提供了url_for()辅助函数,它可以使用程序URL映射中保存的信息生成URL。

使用url_for()生成动态地址时,将动态部分作为关键字参数传入。
utl_for('user',name='john',_external=True)

静态文件 HTML代码中引用的图片,JavaScript源码文件和CSS,就是静态文件。
示例:在程序的基模板中放置favicon.ico图标,这个图标会显示在浏览器的地址栏中
#templates/base.html:定义收藏夹图标{% block head %} {{ super() }} {% endblcok %}

注意如何使用 super() 保留基模板中定义的块的原始内容。
使用Flask-Moment本地化日期和时间 JavaScript开发的优秀客户端开源代码库,名为moment.js,它可以在浏览器中渲染日期和时间。
示例:初始化Flask-Moment
from flask.ext.moment import Moment moment=Moment(app)

示例:在基模板的scripts块中引入库
{% block scripts %} {{ super() }} {{ moment.include_moment() }} {% endblcok %}

示例:加入datetime变量
from datetime import datetime@app.route('/') def index(): return render_template('index.html',current_time=datetime.utcnow())

示例:使用Flask-Moment渲染时间戳
The local date time is {{ moment(current_time).format('LLL') }}.
That was {{ moment(current_time).fromNow(refresh=True) }}

    推荐阅读