• Django的路由规则


    初探路由

    一个完整的路由包含:路由地址、视图函数(或者视图类)、可选变量和路由命名。

    下面本人就Django路由中一些注意点与大家分享

    1.路由变量的设置

    Django在定义路由时,可以对路由设置变量值,使路由具有多样性。路由的变量类型有字符类型、整形、slug和uuid,最为常用的使字符类型和整形。各个类型说明如下 :

    • 字符类型:匹配任何非空字符串,但不含斜杠。如果没有指定类型,就默认使用该类型。
    • 整形:匹配0和正整数。
    • slug:可以理解为注释、后缀或附属等概念,常作为路由的解释性字符。可以匹配任何ASCII字符以及连接符和下划线,能使路由更加清晰易懂。
    • uuid:匹配一个uuid格式的对象。为了防止冲突,规定必须使用 ” - “ 并且所有字母必须小写,例如:1515-0osdga-474adsgs。

    根据上述变量类型,在Django项目的  应用文件夹  中的urls.py里新定义路由,并且带有字符类型、整形和slug的变量,代码如下:

    urlpatterns = [
        path('<year>/<int:month>/<slug:day>', views.myvariable)
    ]

    2.命名空间 namespace

    在 Django项目文件夹 的urls.py中重新定义路由信息:

    urlpatterns = [
        path('admin/', admin.site.urls),
        path('app01/', include(('app01.urls', 'app01'), namespace='app01')),  
    ]

    如上代码所示,若要对路由设置参数namespace,则参数arg必须以元组格式表示,并且元组的长度必须为2。元组的元素说明如下:

    • 第一个元素为项目应用的urls.py文件,比如('app01.urls' , 'app01')的 ”app01.urls“ ,这是代表项目应用index的urls.py 文件。
    • 第二个元素可以自行命名,但不能为空,一般情况下是以项目应用的名称进行命名,如('app01.urls' , 'app01')的 ”app01“ 是以项目应用app01进行命名的。

    3.路由命名 name

    在Django项目的  应用文件夹  中的urls.py里新定义路由

    urlpatterns = [
        path('register/', account.register, name='register'),  
        path('login/', account.login, name='login'),  
        re_path('payment/(?P<policy_id>d+)/', home.payment, name='payment'),
    ]

    上述路由都设置了参数:name,这是对路由进行命名,它是路由函数 path 或 re_path 的可选参数。有利于在模板和视图函数中进行反向解析。

    注意:在实际开发中,我们支持使用路由命名,因为网站更新或防止爬虫程序往往需要频繁修改路由地址,倘若在视图或模板等其他功能模块里使用路由地址,当路由地址发生更新变换时,这些模块里所使用的路由地址也要随之修改,这样就不利于版本的变更和维护;相对而言,如果在这些功能模块里使用路由命名来生成路由地址,就能避免路由地址的更新维护问题。

    以上就是本人与各位分享的Django路由相关知识点,如想要深入了解还请访问Django文档:https://docs.djangoproject.com/zh-hans/3.1/topics/http/urls/

    如有不足,还请各位批评指正。

  • 相关阅读:
    MySQL 和 Oracle 在 MyBatis 使用中的区别
    nodeppt:网页版 PPT
    在 sql 语句出现 warning 之后,立刻执行 `show warnings;` 就可以看到 warning 提示信息
    MySQL 列,可选择的数据类型(通过sql命令查看:`help create table;`)
    create table 推荐规则
    MySQL 中的变量:系统变量(包括:会话变量、全局变量)、用户变量(包括:局部变量、用户变量)
    MySQL 有用的查询语句
    MySQL 遇到错误集锦
    VARCHAR(N)类型,utf8编码,则N最大值为多少,n表示什么?
    MySQL 的严格模式
  • 原文地址:https://www.cnblogs.com/xcbb/p/14664168.html
Copyright © 2020-2023  润新知