05.路由规则及地址动态参数

新建站点地址应该如何规划

  1. 地址应该尽量简短
  2. 地址应该保持有特殊的语义,通过看到地址名猜想到代表什么内容
  3. 目录的层级不宜过深,否则会过于复杂不利于维护

app.add_url_rule()添加地址规则

在特定的地方定义视图函数

def json():
    student = {
        'name':'Tom',
        'age' : 25,
        'email' : '[email protected]'
    }
    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为动态参数
def article_list(aid):    #动态参数传入形参
    return f"欢迎观看新闻文章: {aid}"

动态参数的类型可以加以限制,方法为类型名+冒号,可以限制aid只接受int类型参数。
设置了动态参数的路由无法访问不包含参数的地址

@app.route('/article/')
@app.route('/article//')
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//', 'article_detail', article_list)

除了在add_url_rule函数里指定地址规则、终结点、视图函数之外,我们还可以通过option选项来指定defaults,default={'key' : value}。

总结:

了解了路由的规则,既可以通过app.route装饰器来装饰,也可以通过app.add_url_rule方法来添加。如果先在地址栏中传递一些参数,我们可以通过request来获取,也可以直接写到地址栏中,给他取个名称,对应到视图函数的形参里面,还可以通过一些选项参数来指定动态参数的默认值。

你可能感兴趣的:(05.路由规则及地址动态参数)