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)

user.html改写为衍生模板后的新版本:
templates/user.html:使用Flask-Bootstrap的模板

{% extends "bootstrap/base.html" %}

{% block title %}Flasky{% endblcok %}

{% block navbar %}

{% endblock %}

{% block content %}
{% 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 %}

{% 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) }}

你可能感兴趣的:(2019-06-03Flask第二集)