video5
flask Features:
1, as a framework, introduction and high scalability.
2, flask-related dependence (jinja2, werkzeug) excellent design.
3, the development of efficient, such as the SQL ORM
video6 debug mode
I only recommend run-> edit
video7 profile
1, papers
If the file without a Road King, can be added to make it silent when not being given path can not be found.
2, the conventional way
video8 URL in two mass participation
acceptable path '/'.
Can accept multiple URL '/' is:
Acceptable UUID:
Universe are unique random number, you can call the shots key.
any: You can specify multiple path
1 @app.route('/<any(blog,user):url_path>/<id>') 2 def detail(url_path,id): 3 if url_path == 'blog': 4 return 'Blog:%s' %id 5 else: 6 return 'User:%s' %id
Action: different URL corresponding to the same view function will do.
video9 url_for
带参数的list函数中的page代入url_for的过程。
如果多带一个count呢?
则将以查询字符串的形式出现,结果为:
带参数的视图函数有个功能:
当你浏览一个网页想要评论的时候发现自己没登陆,等你登陆后又能回到你刚才要评论的页面,这种情况下可以实现通过url_for带参数的视图函数。
先用arg获取那个url后缀参数,通过url_for返到评论页面。
video10 自定义url_for转换器
转换器中已经存在int,float,string,UUID,path,any。那么我们定义一个电话号码的?
from werkzeug.routing import BaseConverter
在BaseConverter中Ctrl+B查看源代码:
发现一个父类: class BaseConverter(object) 而any继承了这个父类: class AnyConverter(BaseConverter): 且最后有一个对应关系: #: the default converter mapping for the map. DEFAULT_CONVERTERS = { 'default': UnicodeConverter, 'string': UnicodeConverter, 'any': AnyConverter, 'path': PathConverter, 'int': IntegerConverter, 'float': FloatConverter, 'uuid': UUIDConverter, }
也就是说我们自己可以定义一个:
class TelephoneConverter(BaseConverter):
电话转换器去继承父类,然后加入默认映射表中。
1 from flask import Flask 2 from werkzeug.routing import BaseConverter 3 4 app = Flask(__name__) 5 6 #url中限定手机号码的格式 7 class TelephoneConverter(BaseConverter): 8 regex = r'1[345678]\d{9}' 9 num_convert = int 10 app.url_map.converters['tel'] = TelephoneConverter 11 12 @app.route('/tel/<tel:my_tel>') 13 def gg(my_tel): 14 return '%s' %my_tel
第8行表示11位的电话号码。
第10行表示添加到默认映射表中。
结果为:
下面定义a+b形式的转换器:
先看代码:
1 #现有需求需要访问a、b两个板块的文章返回出来 2 from werkzeug.routing import BaseConverter 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return 'hahaha' 6 app.url_map.converters['list'] = ListConverter 7 8 @app.route('/list/<list:bankuai>') 9 def aabb(bankuai): 10 return '%s' %bankuai
再看结果:
我们发现这个to_python函数中的value实际上接受了url中的a+b,但是这个函数中我们的写法是不管传入什么我们都返回hahaha,所以页面上返回了hahaha。也就是说url中的值会经由to_python传给视图函数。to_url相反。
如果我们在to_python函数中写上别的东西呢?岂不是能实现我们想要的转换器?
1 #现有需求需要访问a、b两个板块的文章返回出来 2 from werkzeug.routing import BaseConverter 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return value.split('+') 6 app.url_map.converters['list'] = ListConverter 7 8 @app.route('/list/<list:bankuai>') 9 def aabb(bankuai): 10 return '%s' %bankuai
第5行是变化后的代码,效果如下:
再讲讲to_url。
1 from werkzeug.routing import BaseConverter 2 from flask import url_for 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return value.split('+') 6 def to_url(self, value): 7 print("value:",value) 8 return "+".join(value) 9 app.url_map.converters['list'] = ListConverter 10 11 @app.route('/list/<list:bankuai>') 12 def aabb(bankuai): 13 return '%s' %bankuai 14 15 @app.route('/') 16 def hello_world(): 17 print(url_for('aabb',bankuai=['d','c'])) 18 return 'to_url'
17的bankuai进入到to_url中,传进去的是['d','c'],所以第7行返回了这个值,然后return回“+”连接的dc,最终在url_for的时候就打印成了‘/list/d+c’
结果:
第一个值是7行的,第二个是17行的。
总结下:
video11 url_for小细节
先看代码块
1 @app.route('/list/') 2 def hello_world(): 3 return 'Hello World!'
再看效果:
我们发现我们在第1行list后带了个“/”,然后在浏览器输入时候带不带这个斜杠都能访问到。
再看不带斜杠的:
所以我们选择第一种,因为第二种方法中可能代码中没写url写了的时候会出故障。
get和post
video12 重定向详解
video13 关于响应(Response)