视图高级
add_url_rule(rule,endpoint=None,view_func=None)
用来添加url与视图函数的映射,如果没有填写endpoint
默认会使用view_func的名字作为endpoint .以后使用
url_for 时,就要看映射时有没有传递endpoint参数
如果传递了,就应该使用endpoint的字符串
否则就应该使用view_func的名字
app.route(rule,**options)
底层也是使用add_url_rule 来实现url与视图函数映射
类视图
标准类视图
1,必须继承 flask.views.View
2,必须实现 dispatch_request 方法,请求过来后,都会执行这个方法。
3,返值就相当于之前的函数一样,也必须返回 Response 或子类的对象或字符串或元组
4,必须通过 app.add_url_rule(rule,endpoint,view_func) 来做url与视图的映射
view_func 这个参数,需要使用as_view 方法转换
5,如果指定了endpoint 时,那么使用url_for 反转时,就必须使用endpoint指定的值。
如果没有指定endpoint ,那么可以用as_view中的名字
app.add_url_rule(’/list/’,endpoint=‘my_list’,view_func=ListView.as_view(‘list’))
with app.test_request_context():
print(url_for(‘my_list’))
基于请求方法的类视图
1,根据请求的 method 来执行不同的方法,如果用户是发送的get 请求,
那和将会执行这个类的get方法,如果用户发送的是post 请求,
那么将会执行这个类的post 方法。其他的method 类似,比如:delete,put
2,这种方法,可以让代码更简洁
类视图中的装饰器
1,如果是函数视图,那和自已定义 的装饰器必须放在app.route 下面,
否则装不起作用
2,需重写类视图的一个类属性 decorators, 这个类属性可以是元组 列表