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) }}
推荐阅读
- EffectiveObjective-C2.0|EffectiveObjective-C2.0 笔记 - 第二部分
- 图书集合完毕
- Activiti(一)SpringBoot2集成Activiti6
- 雅集
- 以读攻“毒”唤新活动曹彦斌打卡第二天
- 《格列佛游记》第二卷第五章概括
- [青春]翔(五)
- 解读《摩根集团》(1)
- 《卓有成效的管理者》第二十二堂课(创造英雄)
- 私有化轻量级持续集成部署方案--03-部署web服务(下)