一、Bootstrap

  Bootstrap,来自 Twitter,是目前最受欢迎的前端框架。

  Python中,同样可以使用Bootstrap。

  1. 导入Bootstrap库

from flask_bootstrap import Bootstrap

  2. 实例化

Bootstrap(app)

  Samply.py

# coding:utf-8
from flask import Flask,render_template,request,url_for
from flask_bootstrap import Bootstrap app = Flask(__name__)
Bootstrap(app) @app.route('/')
def home():
return render_template('home.html',title_name = 'welcome') @app.route('/service')
def service():
return 'service' @app.route('/about')
def about():
return 'about' if __name__ == '__main__':
app.run(debug=True)

  3. 定义块内容

  home.html

{% extends 'bootstrap/base.html' %}  #声明继承
{% import '_macro.html' as ui %} {% block title %}{{ title_name }}{% endblock %} {% block content %}
<div class="page-header">
<div class="container">
<h1>{{ self.title() }}</h1>
</div>
</div>
<div class="container">
{{ ui.input('username') }}
{{ ui.input('password',type='password') }}
</div>
{% endblock content %} {% block head %}
{{ super() }}
{% include 'includes/_head.html' %}
{% endblock %}

  这时候我们看一下,运行出来是什么样子

------------------------------------------------------------------------------------------------

  基本的内容有了,如果我们想要加上一个标题栏

  可以使用Flask-Nav扩展,如何使用呢?

  1. 导入库

from flask_nav import Nav
from flask_nav.elements import *

  2. 实例化并注册一个导航栏

nav=Nav()
nav.register_element('top',Navbar(u'Flask入门',
View(u'主页','home'),
View(u'关于','about'),
Subgroup(u'项目',
View(u'项目一','about'),
Separator(),
View(u'项目二', 'service'),
),
))

  3. 初始化这个实例

nav.init_app(app)

  以上这些都是在Samply.py文件里

  4. 渲染并定义成块,home.html

{% block navbar %}
{{ nav.top.render() }}
{% endblock %}

  这时候我们看一下,运行出来是什么样子

  5. 增加样式表

  这个时候我们发现配色太单调了,这时候我们可以引用 BootstrapCDN (地址)的CSS样式表,只要把地址填入href中就可以

    不改变原head的情况下,又增加css样式表

{% block styles %}
{{ super() }}
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootswatch/3.3.7/darkly/bootstrap.min.css">
{% endblock %}

  这时候我们看一下,运行出来是什么样子

-------------------------------完成@@-----------------------------------

参考文档:

1. Bootstrap中文网

2. Flask-Nav 文档

3. W3C Bootstrap教程

4. BootstrapCDN页面

附录:

Sample.py

# coding:utf-8
from flask import Flask,render_template,request,url_for
from flask_bootstrap import Bootstrap
from flask_nav import Nav
from flask_nav.elements import *
app = Flask(__name__)
Bootstrap(app)
nav=Nav()
nav.register_element('top',Navbar(u'Flask入门',
View(u'主页','home'),
View(u'关于','about'),
Subgroup(u'项目',
View(u'项目一','about'),
Separator(),
View(u'项目二', 'service'),
),
)) nav.init_app(app)
@app.route('/')
def home():
return render_template('home.html',title_name = 'welcome') @app.route('/service')
def service():
return 'service' @app.route('/about')
def about():
return 'about' @app.template_test('current_link')
def is_current_link(link):
return link == request.path if __name__ == '__main__':
app.run(debug=True)

 home.html

{% extends 'bootstrap/base.html' %}
{% import '_macro.html' as ui %} {% block title %}{{ title_name }}{% endblock %} {% block content %}
<div class="page-header">
<div class="container">
<h1>{{ self.title() }}</h1>
</div>
</div>
<div class="container">
{{ ui.input('username') }}
{{ ui.input('password',type='password') }}
</div>
{% endblock content %} {% block head %}
{{ super() }}
{% include 'includes/_head.html' %}
{% endblock %} {% block styles %}
{{ super() }}
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootswatch/3.3.7/darkly/bootstrap.min.css">
{% endblock %} {% block navbar %}
{{ nav.top.render() }}
{% endblock %}

 _macro.html

{# 定义宏 #}
{% macro input(name,value='',type='text',size=20) %}
<input type="{{ type }}"
name="{{ name }}"
value="{{ value }}"
size="{{ size }}"/>
{% endmacro %}

最新文章

  1. 讲座:Modeling User Engagement for Ad and Search
  2. 修改nginx版本名称伪装任意web server
  3. HTML5新增的标签
  4. php大小写转换
  5. 【Android 界面效果40】Android4.0-Fragment框架实现方式剖析(一)
  6. Ubuntu中设置环境变量详解
  7. 如何通过CSS3实现背景图片色彩的梯度渐变
  8. wafer
  9. Visual Studio shortcut keys
  10. ClusterWare 服务介绍
  11. 菜鸟教程工具(三)——Maven自己主动部署Tomcat
  12. Pandas系列(六)-时间序列详解
  13. 论文笔记:DARTS: Differentiable Architecture Search
  14. 【转】Asp.Net Core2.0获取客户IP地址,及解决发布到Ubuntu服务器获取不到正确IP解决办法
  15. mk文件配置第三方jar包,so文件
  16. 前端(主要html/css)学习笔记
  17. 使用python调用淘宝的ip地址库查询接口结合zabbix判断dnspod域名解析是否正确
  18. [EXP]Jenkins 2.150.2 - Remote Command Execution (Metasploit)
  19. 父页面操作嵌套iframe子页面的HTML标签元素
  20. PCM转MP3工具的封装

热门文章

  1. Linux进程实践(5) --守护进程
  2. (二十六)静态单元格(Cell)
  3. Android Studio中创建Kotlin For Android项目
  4. 《java入门第一季》之面向对象(面向对象案例详解)
  5. Struts2(XWork)中的Container 一
  6. 如何写好一个UITableView(完整版)
  7. IP封包的封装 - 首部内容
  8. HBase丢失数据的故障和原因分析
  9. Emmet之html语法
  10. spring boot + quartz 集群