当前位置:   article > 正文

Web前端之Flask框架--集成Bootstrap_flask bootstrap

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)
    • 1
    • 2
    • 3

    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 %}
      • 1
      • 2
      • 3
      {#使页面有总体的前缀#}
      {% block title %}
      {{ super() }}主页
      {% endblock %}
      • 1
      • 2
      • 3

      四、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>
      • 1
      • 2
      • 3
      <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>
      • 1
      • 2
      • 3

      五、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 %}
      • 1
      • 2
      声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/185714
      推荐阅读
      相关标签
        

      闽ICP备14008679号