新建站点地址应该如何规划
- 地址应该尽量简短
- 地址应该保持有特殊的语义,通过看到地址名猜想到代表什么内容
- 目录的层级不宜过深,否则会过于复杂不利于维护
app.add_url_rule()添加地址规则
在特定的地方定义视图函数
def json():
student = {
'name':'Tom',
'age' : 25,
'email' : 'tom@gogofx.cn'
}
return jsonify(student)
app.add_url_rule('/json/', endpoint='json', view_func=json)
#将定义好的函数引用传递到view_func
这样做的好处是可以把视图函数移走,可以在其他地方定义好函数,然后在需要使用的地方引入函数的包,最后将引用添加到add_url_rule
里面。
例如在product文件下定义了一个函数product_list
我们可以通过如下方式在路由文件中绑定该函数
from product import product_list #从product模块下导入product_list函数
app.add.url_rule('/products/', endpoints='product_list', view_func=product_list)
这样做的好处是分解了任务,降低了项目的耦合度,提高了代码的维护扩展的灵活性。
地址栏参数
之前我们了解过,想要获取地址栏参数可以导入request包使用request.args.get方法获取地址栏的查询字符串。
@app.route('/article/')
def article_list():
aid = request.args.get('id', 0) #获取id的值,默认为0
return f"欢迎观看新闻文章: {aid}"
动态参数
在规划路由的时候,通过尖括号来设置动态参数,动态参数是可变的。在视图函数中将动态参数作为形参传入做下一步的处理。
@app.route('/article/<aid>/') #尖括号内的aid为动态参数
def article_list(aid): #动态参数传入形参
return f"欢迎观看新闻文章: {aid}"
动态参数的类型可以加以限制,方法为类型名+冒号,<int:aid>可以限制aid只接受int类型参数。
设置了动态参数的路由无法访问不包含参数的地址
@app.route('/article/')
@app.route('/article/<aid>/')
def article_list(aid=1):
return f"欢迎观看新闻文章: {aid}"
上述代码有俩个路由装饰器,表明在没有aid的情况下也可以正常访问article页面,并且在视图函数中给aid加了默认值1,也就是说在直接访问article页面的时候aid的值为1,解决了无动态参数访问页面时报错的问题。
当然通过app.add_url_rule
也可以设置。
app.add_url_rule('/article/', 'article_detail', article_list, defaults={'aid' : 100})
app.add_url_rule('/article/<int:aid>/', 'article_detail', article_list)
除了在add_url_rule函数里指定地址规则、终结点、视图函数之外,我们还可以通过option选项来指定defaults,default={'key' : value}。
总结:
了解了路由的规则,既可以通过app.route
装饰器来装饰,也可以通过app.add_url_rule
方法来添加。如果先在地址栏中传递一些参数,我们可以通过request来获取,也可以直接写到地址栏中,给他取个名称,对应到视图函数的形参里面,还可以通过一些选项参数来指定动态参数的默认值。