路由控制

一、简单路由配置

url(r'^booklist$', views.booklist)
  • 第一个参数是正则表达式,第二个参数是视图函数
  • 每个正则表达式前面的'r' 是可选的但是建议加上。它告诉Python 这个字符串是“原始的” —— 字符串中任何字符都不应该转义
url(r'booklist', views.booklist)
url(r'booklistadd', views.booklistadd)

如果不加^ 和 $ ,由于路由匹配是从上往下匹配的,若是要匹配 booklistadd ,则很可能会匹配到booklist就会停止匹配

二、无名分组

url(r'^booklist/([0-9]{4})/([0-9]{2})/$', views.booklist)

def booklist(request, a, b)  或者 def booklist(request, *args)
  • 按位置传参
  • () 表示分组,分组后,会把分组出来的数据当做位置参数,传递到视图函数
  • 视图函数中必须要有位置参数接收分组出来的数据。由于分组出来的数据可能有很多,所以也可以用 *args 来用一个元组接收所有数据。

三、有名分组

url(r'^booklist/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.booklist)

def booklist(request, year, month)
  • 按关键字传参
  • 分组后,会把分组出来的数据按关键字传参,传递到视图函数
  • 视图函数需要定义形参来接收,并且视图函数中形参的名字要跟分组的名字一样,与顺序无关

四、反向解析

1、什么是反向解析

在Django中,经常需要获取某条URL,为生成的内容配置URL链接。

urlpatterns =[ url ( r'^booklist$', views.booklist ) , ]

如在a标签中,<a href='/booklist/'>,倘若url发生了变化,就必须要去html中手动修改a的href,这样会浪费大量的工作时间。因此,Django提供一种方案,在url中提供一个name参数,相当于是给url取了一个名字。

url(r'^booklist$', views.booklist,name='book_url')

2、使用反向解析获取url

(1)三种url
# 1.无参
url(r'^booklist$', views.booklist,name='book_url')
# 2.有参,无名分组
url(r'^userlist/([0-9]{4})/([0-9]{2})/$',views.userlist,name='user_url')
# 3.有参,有名分组
url(r'^manlist/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$',views.manlist,name='man_url')
(2)模板层
# 1.无参
<form action="{{% url 'book_url' %}}">
# 2.有参,无名分组, 2008 和 12 表示两个参数,即两个分组
{{% url 'user_url' 2008 12 %}}
# 3.有参,有名分组
{{% url 'man_url' 2018 12 %}} 或者 {{% url 'man_url' year=2018 month=12 %}}
(3)视图层
from django.conf.urls import redirect,reverse 

# 1.无参
url=reverse('book_url')
return redirect(url)
# 2.有参,无名分组, 2008 和 12 表示两个参数,即两个分组
url=reverse('user_url',args=(2018,12,))
# 3.有参,有名分组
url=reverse('man_url',args=(2018,12,))
或者
url=reverse('man_url',kwargs={'year':2018,'mounth':12})

五、路由分发

1、在不同的app中创建子路由urls.py

2、在总路由中配置

from django.conf.urls import include 

url(r'^app01/',include('app01.urls'))
url(r'^blog/',include('blog.urls'))

3、在不同app的urls中配置路由

# 在app01中,urls.py
url(r'booklist$',views.booklist)
# 在blog中,urls.py
url(r'userlist$',views.userlist)

六、名称空间(一般不使用)

1、什么是名称空间

命名空间(英语:Namespace)是表示标识符的可见范围。一个标识符可在多个命名空间中定义,它在不同命名空间中的含义是互不相干的。

# 总路由
url(r'^app01/',include('app01.urls',namespace='app01'))
url(r'^blog/',include('blog.urls',namespace='blog'))
# 子路由
# app01中
url(r'^publish/$', views.publish,name='test')
# blog中
url(r'userlist$',views.userlist,name='test')

2、使用名称空间

名称空间 : 路由别名

视图层:url = reverse('blog:test')
模板层:{% url 'app01:test'%}

七、伪静态

为了更好的被搜索引擎收录而通过一定的规则,把动态页面的地址转换成以htm或html结尾的地址,看起来是静态的,实际是依然是动态页面。

例如访问http://127.0.0.1:8000/book/4.html,它看上去是静态网站,但是其实其中的数据是通过后台获取实时更新的。

# 路由,用html结尾
url(r'^book/(?P<id>\d+.html)',views.book),

八、Django 2.x和Django 1.x 路由层区别

1、Django2.x中

  • re_path:跟1.0的url用法相同
  • path:传的路径,是准确路径
urlpatterns = [path('test/',view.test), ]

2、转换器

5个转换器

path('test/<path:year>', views.re_test)
# year 表示名字,path表示year是path类型的
str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
int,匹配正整数,包含0。
slug,匹配字母、数字以及横杠、下划线组成的字符串。
uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
path,匹配任何非空字符串,包含了路径分隔符(/)(不能用?)

3、自定义转换器

# 1 定义一个类:
class MyCon:
# 写一个正则表达式
regex = '[0-9]{4}'
# 匹配出來的数据,会传到这里,retrun回去的,会被视图函数接收
def to_python(self, value):
return int(value)
# 反向解析用的
def to_url(self, value):
return '%04d' % value
# 2.注册转换器
from django.urls import register_converter
register_converter(MyCon,'yyy')
# 3.使用自定义转换器
path('test/<yyy:year>', views.re_test,name='test'),

九、APPEND_SLASH

# 是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True
  • Django settings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 其作用就是自动在网址结尾加'/'

  • 默认APPEND_SLASH = True,即会自动在网址末尾加上 ‘/’

如访问 https://www.cnblogs.com 时,默认会加上 ‘/’,相当于方位了 https://www.cnblogs.com/

如果设置了APPEND_SLASH = False,访问 https://www.cnblogs.com 就不会加’/‘,就找不到页面

随机推荐

  1. poj 3321 Apple Trie

    /* poj 3321 Apple Trie 这道题的关键是如何将一个树建成一个一维数组利用树状数组来解题! 可以利用dfs()来搞定,我们在对一个节点深搜后,所经过的节点的数目就是该节点的子树的数目 ...

  2. 关于安装qt之后的qmake命令

    今天通过在archlinux中安装qt5发现了关于qmake这个命令的一些事情. 1. /bin/qmake 是 /bin/qtchooser 的符号链接,/bin/qtchooser 由一个叫 qt ...

  3. Deferred解决JS同步问题

    测试脚本: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...

  4. HTML: margin詳解

    margin:10px; 設置塊元素的上,右,下,左方向的值同爲10px margin:10px 30px; 設置塊元素的上和下爲10px,左和右爲30px; margin:10px 20px 30p ...

  5. 驱动之module_init/module_exit

    在前面helloworld的编写里面,我们使用了两个宏分别是module_init和module_exit,这里分析下为什么使用这两个宏. 在写模块的时候有两个特殊的函数,分别是init_module ...

  6. js获取名字为XX的标签

    $("input[name='XX']"); <input name="address_select" type="radio" va ...

  7. Machine Learning #Lab1# Linear Regression

    Machine Learning Lab1 打算把Andrew Ng教授的#Machine Learning#相关的6个实验一一实现了贴出来- 预计时间长度战线会拉的比較长(毕竟JOS的7级浮屠还没搞 ...

  8. C#仪器数据文件解析-XPS文件

    XPS为微软推出的类似于Adobe PDF的一种文件格式,个人认为XPS很好,但毕竟PDF已经被大家所熟知,因此XPS的使用很少,也少有仪器数据输出为该格式. XPS百度百科:https://baik ...

  9. 动态创建 script 实现跨域请求数据

    动态创建script标签 (由事件触发) 在我们需要请求数据的时候我们就可以动态的创建 script 标签 src设置为我们需要请求数据的地址 另外我们可以附加参数 ?后面附加参数 例如 :?参数=1 ...

  10. 理解WebKit和Chromium: Chromium的多进程资源加载机制

    转载请注明原文地址:http://blog.csdn.net/milado_nju ##概述 前面介绍了WebKit中的资源加载机制,其实它只是一个框架性的东西,实际的资源加载依赖于各个WebKit移 ...