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 %}
<div class="navbar navbar-inverse" role="navigation">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle"
data-toggle="collapse" data-target=".navbar-collapse">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="/">Flasky</a>
</div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li><a href="/">Home</a></li>
</ul>
</div>
</div>
</div>
{% endblock %}
{% block content %}
<div class="container">
<div class="page-header">
<h1>Hello, {{ name }}!</h1>
</div>
</div>
{% 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 %}
<div class="page_header">
<h1>Hello,{{ name }}!</h1>
</div>
{% 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() }}
<link rel="shortcut icon" href="{{ url_for('static',filename='favicon.ico') }}"
type="image/x-icon">
<link rel="icon" href="{{ url_for('static',filename='favicon.ico')}}"
type="image/x-icon">
{% 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渲染时间戳
<p>The local date time is {{ moment(current_time).format('LLL') }}.</p>
<P>That was {{ moment(current_time).fromNow(refresh=True) }}</p>