Today 19年2月16日,距离金三银四的招聘月份越来越近了.简历上的项目也成了目前最棘手的问题,需要迫切做出一个能拿的出手的项目.正好手头有一个Flask相关的小程序订餐应用,并且这个项目的应用场景很广泛,知识涉及面也很有深度,是一个可以拿来练手的项目。So , 要抓紧快速复习一下flask知识点,马上跟小伙伴们投入开发。。
Flask简介
Flask是一个基于Python并且依赖于Jinja2模板引擎和Werkzeug WSGI服务的一个微型框架(Micro Framework),并且是基于 MTV 框架模式开发出来的框架
拓展:
- MTV框架 (Flask,Django)
M : Models层,模型层,负责与数据库打交道
T : Templates层,模板层,处理用户显示的内容,如html
V : Views层,视图层,处理与用户打交道的内容(请求和响应) - 经典的 MVC框架
M : Models层,模型层,负责与数据库打交道
V : Views层,视图层,处理用户显示的内容,如html
C : Controller层,控制器层,处理与用户打交道的内容(请求和响应)
Template层 知识点回顾
1.URL的反向解析 url_for
正向解析:程序自动解析,会根据访问路径(@app.route(‘xxx’)),自动来匹配处理函数
反向解析:通过视图处理函数的名称自动生成对应的访问路径
在Flask中要实现反向解析的话,需要使用:
from flask import url_for
url_show = url_for(funName,args)
# funName : 要生成地址所对应的函数名
# args : 该地址中要用到的参数
# url_show 就是反向根据视图函数名称生成它对应的url地址
具体代码示例:
from flask import Flask, url_for
app = Flask(__name__)
# 没有参数的url地址反向解析示例,通过index函数名,反向生成对应的请求地址
@app.route('/index')
def index():
return "<h1>这是首页</h1>"
@app.route('/demo')
def demo():
url_index = url_for('index')
return '<a href=%s>去往index函数对应的url地址</a>'% url_index
#通过复杂的访问地址+简单的方法方法名称+参数
@app.route('/admin/login/user/tarena/form/url/show/<name>')
def show(name):
return "传递进来的参数为:"+name
@app.route('/url')
def url():
#通过show函数名以及name参数反向生成访问地址
url_show=url_for('show',name='wangwc')
print('访问地址:'+url_show)
return "<a href='%s'>访问show('wangwc')</a>" % url_show
if __name__ == "__main__":
app.run(debug=True)
2.Template层中的macro标签(宏)使用
- (1)作用:相当于模板中声明的函数(通常用来显示数据文本等)
- (2)语法:
{% macro 函数名(形参列表) %}
xxx xxx
{% endmacro %} - (3)使用方法: 在独立的模板文件中声明宏
1.创建 macro.html 模板文件
作用:定义项目中要用到的所有的宏
代码如下:
1.在模板层写好声明的宏并加以应用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title> macro.html </title>
</head>
<body>
{% macro show_li(str)%}
<li>
<p style="font-size: 20px">内容如下:</p>
<span style="color: red">
{{ str }}
</span>
</li>
{% endmacro %}
<ul>
{% for name in list %}
{{ show_li(name) }}
{% endfor %}
</ul>
</body>
</html>
然后通过视图函数传一下参数即可
@app.route('/01-macro')
def macro_views():
list=['张三','李四','王五','校长']
return render_template('macro.html',list=list)
2.在使用的网页中,导入 macro.html 模板
{% import ‘macro.html’ as macros %}
代码示例如下:
首先写好存放宏的模板(.html文件) 两个宏
{% macro show_list(list) %}
<ul>
{% for name in list %}
<li>
<p style="color:red;">
姓名:{{ name }}
</p>
</li>
{% endfor %}
</ul>
{% endmacro %}
{% macro show_p(str) %}
<p style="font-size: 20px;font-weight: bold">
内容为:{{ str }}
</p>
{% endmacro %}
然后再去负责显示的模板html文件中引入并加以运用
<h1>调用macros.html中的宏</h1>
{% import 'macros.html' as macros %}
{{ macros.show_list(list) }}
{% for name in list %}
{{ macros.show_p(name) }}
{% endfor %}
网页上输出显示结果: