一、URL传参
1.1 传递参数:
传递参数的语法是:/<参数名>/
。然后在视图函数中,也要定义同名的参数。
1.1 参数的数据类型:
- 如果没有指定具体的数据类型,那么默认就是使用
string
数据类型。 int
数据类型只能传递int
类型。
float
数据类型只能传递float
类型。
path
数据类型和string
有点类似,都是可以接收任意的字符串,但是path
可以接收路径,也就是说可以包含斜杠。
uuid
数据类型只能接收符合uuid
的字符串。uuid
是一个全宇宙都唯一的字符串,一般可以用来作为(用户)表的主键。int类型自增主键可能泄露网站信息。
any
数据类型可以在一个url
中指定多个路径。例如:
@app.route('/<any(blog,article):url_path>/<id>/')
def detail(url_path,id):
if url_path == 'blog':
return '博客详情:%s' % id
else:
return '文章详情:%s' % id
接收用户传递的参数:
- 第一种:使用path的形式(将参数嵌入到路径中),就是上面讲的。
- 第二种:使用查询字符串的方式,就是通过
?key=value
的形式传递的。@app.route('/d/') def d(): wd = request.args.get('wd') return '您通过查询字符串的方式传递的参数是:%s' % wd
- 如果你的这个页面的想要做
SEO
优化,就是被搜索引擎搜索到(前台),那么推荐使用第一种形式(path的形式)。如果不在乎搜索引擎优化(后台),那么就可以使用第二种(查询字符串的形式)。
二、url_for的使用(反转路由)
url_for
的基本使用:
url_for
第一个参数,应该是视图函数的名字的字符串。后面的参数就是传递给url
。
如果传递的参数之前在url
中已经定义了,那么这个参数就会被当成path
的形式给url
。如果这个参数之前没有在url
中定义,那么将变成查询字符串的形式放到url
中。
@app.route('/post/list/<page>/')
def my_list(page):
return 'my list'
print(url_for('my_list',page=1,count=2))
# 构建出来的url:/my_list/1/?count=2
为什么需要url_for
:
- 将来如果修改了
URL
,但没有修改该URL对应的函数名,就不用到处去替换URL了。 url_for
会自动的处理那些特殊的字符,不需要手动去处理。url = url_for('login',next='/') # 会自动的将/编码,不需要手动去处理。 # url=/login/?next=%2F