Web前端之Flask框架--集成Bootstrap

一、Bootstrap简介

Bootstrap http://getbootstrap.com/ 是Twitter 开发的一个开源框架。
它提供的用户界面组件可用于创建整洁且具有吸引力的网页,而且这些网页还能兼容所有现代Web 浏览器。

二、为什么需要在Flask中集成Bootstrap?

Flask模板集成Bootstrap。一般情况下Flask都是搭配Jinja2模板引擎来实现视图展现,
不过现在Bootstrap比较流行,内置的样式也比较好看,有利于提高开发效率

三、Flask中如何使用集成的Bootstrap?

要想在程序中集成Bootstrap,显然要对模板做所有必要的改动。
不过,更简单的方法是使用一个名为Flask-Bootstrap 的Flask 扩展,简化集成的过程。

1、Flask-Bootstrap的安装

Flask-Bootstrap 使用pip安装:

pip install -i https://pypi.douban.com/simple flask_bootstrap

2、初始化Flask_Bootstrap

Flask 扩展一般都在创建程序实例时初始化,Flask_Bootstrap的初始化方法:

from flask import Flask
from flask_bootstrap import Bootstrap
app=Flask(__name__)
bootstrap=Bootstrap(app)

3、继承模板

初始化Flask-Bootstrap 之后,就可以在程序中使用一个包含所有Bootstrap 文件的基模板base.html。
这个模板利用Jinja2 的模板继承机制,让程序扩展一个具有基本页面结构的基模板,其中就有用来引入Bootstrap 的元素。

  • Jinja2 中的extends 指令从Flask-Bootstrap 中导入bootstrap/base.html, 从而实现模板继承。
{%extends 'bootstrap/base.html'%}
  • Flask-Bootstrap 中的基模板提供了一个网页框架,引入了Bootstrap 中的所有CSS 和JavaScript 文件。
  • 基模板中定义了可在衍生模板中重定义的块。block 和endblock 指令定义的块中的内容可添加到基模板中。
{#要想使页面显示信息时有总体的前缀时这样设计#}
{% block title %}
西部开源-
{% endblock %}
{#使页面有总体的前缀#}
{% block title %}
{{ super() }}主页
{% endblock %}

四、Bootstrap警告框组件

<div class="alert alert-success" role="alert">...</div>
<div class="alert alert-info" role="alert">...</div>
<div class="alert alert-warning" role="alert">...</div>
<div class="alert alert-danger" role="alert">...</div>
<div class="alert alert-warning alert-dismissible" role="alert">
  <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  <strong>Warning!</strong> 警告!
</div>

五、Flask-Bootstrap自定义模板块

Flask-Bootstrap 的base.html 模板还定义了很多其他块,都可在衍生模板中使用,下表列出了所有可用的块:

块名说明
doc整个html文件
html_attribshtml标签属性
htmlhtml标签中的内容
headhead标签中的内容
titletitle标签中的内容
metas一组meta标签
styles层叠样式表定义
body_attribsbody标签的属性
bodybody标签中的内容
navbar用户定义的导航条
content用户定义的页面内容
scripts文档底部的JavaScript声明

六、Flask-Bootstrap自定义模板块的继承实现

  • 上表中的很多块都是Flask-Bootstrap 自用的,如果直接重定义可能会导致一些问题。
    例如,Bootstrap 所需的文件在styles 和scripts 块中声明。
  • 如果程序需要向已经有内容的块中添加新内容,必须使用Jinja2 提供的super() 函数。
    例如,如果要在衍生模板中添加新的JavaScript 文件,需要这么定义scripts 块:
{% block scripts %} 
{{ super() }}
{% endblock %}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值