Django的url用法

利用Django开发网站,可以设计出非常优美的url规则,如果url的匹配规则(包含正则表达式)组织得比较好,view的结构就会比较清晰,比较容易维护。

最简单的形式



from django.conf.urls import patterns, url
urlpatterns = patterns('',
    url(r'^articles/2003/$', 'news.views.special_case_2003'),
    url(r'^articles/(\d{4})/$', 'news.views.year_archive'),
    url(r'^articles/(\d{4})/(\d{2})/$', 'news.views.month_archive'),
    url(r'^articles/(\d{4})/(\d{2})/(\d+)/$', 'news.views.article_detail'),
)

其中,正则表达式中组匹配出来的结果可以作为positional parameters传递给view.

如果url是www.yourdomain/articles/2005/,则会匹配第二条规则,执行news.views.year_archive('2005').

注意点

  • 域名部分会被过滤掉
  • articles的前面不需要添加/,因为前序url的末尾一定会有/
  • 任何组匹配的变量,都会议字符串的形式传递给view, 虽然通过(\d{4})匹配出了2005,但2005任然会被当做字符串传递给year_archive

利用named group来传递参数

可以通过以下形式为特定的组指定一个名称.

urlpatterns = patterns('',
    url(r'^articles/2003/$', 'news.views.special_case_2003'),
    url(r'^articles/(?P<year>\d{4})/$', 'news.views.year_archive'),
    url(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/$', 'news.views.month_archive'),
    url(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})/$', 'news.views.article_detail'),
)

 

这样的话,组的匹配结果会通过keyword parameters的形式传递给view.例如year_archive(year='2005')

 

利用named group可以为view指定一个默认参数来匹配多条规则。

# URLconf
from django.conf.urls import patterns, url

urlpatterns = patterns('',
    url(r'^blog/$', 'blog.views.page'),
    url(r'^blog/page(?P<num>\d+)/$', 'blog.views.page'),
)

# View (in blog/views.py)
def page(request, num="1"):
    # Output the appropriate page of blog entries, according to num.

 

指定view前缀(提取公因式)

patterns函数的第一个参数即是view的前缀

from django.conf.urls import patterns, url

urlpatterns = patterns('news.views',
    url(r'^articles/(\d{4})/$', 'year_archive'),
    url(r'^articles/(\d{4})/(\d{2})/$', 'month_archive'),
    url(r'^articles/(\d{4})/(\d{2})/(\d+)/$', 'article_detail'),
)

指定多个view前缀

urlpatterns = patterns('myapp.views',
    url(r'^$', 'app_index'),
    url(r'^(?P<year>\d{4})/(?P<month>[a-z]{3})/$','month_display'),
)
urlpatterns += patterns('weblog.views',
    url(r'^tag/(?P<tag>\w+)/$', 'tag'),
)

 

include其它匹配模块

from django.conf.urls import include, patterns, url

urlpatterns = patterns('',
    # ... snip ...
    url(r'^comments/', include('django.contrib.comments.urls')),
    url(r'^community/', include('django_website.aggregator.urls')),
    url(r'^contact/', include('django_website.contact.urls')),
    # ... snip ...
)

当然也可以直接include其它patterns

from django.conf.urls import include, patterns, url

extra_patterns = patterns('',
    url(r'^reports/(?P<id>\d+)/$', 'credit.views.report'),
    url(r'^charge/$', 'credit.views.charge'),
)

urlpatterns = patterns('',
    url(r'^$', 'apps.main.views.homepage'),
    url(r'^help/', include('apps.help.urls')),
    url(r'^credit/', include(extra_patterns)),
)

 

为view函数传递额外参数

from django.conf.urls import patterns, url

urlpatterns = patterns('blog.views',
    url(r'^blog/(?P<year>\d{4})/$', 'year_archive', {'foo': 'bar'}),
)

直接使用view函数

from django.conf.urls import patterns, url
from mysite.views import archive, about, contact

urlpatterns = patterns('',
    url(r'^archive/$', archive),
    url(r'^about/$', about),
    url(r'^contact/$', contact),
)

需要继续研究:Reverse resolution of URLs

参考文献:URL dispatcher

  • 6
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Django 的 DeleteView 是一种方便的视图,可用于删除数据库的一个对象。它基于通用视图,提供了一些内置的方法和属性,使删除操作更加简单和快捷。下面是 DeleteView 的用法: 1. 导入 DeleteView 类 ```python from django.views.generic import DeleteView from django.urls import reverse_lazy from myapp.models import MyModel ``` 2. 定义 DeleteView 类 ```python class MyModelDeleteView(DeleteView): model = MyModel # 要删除对象的模型 success_url = reverse_lazy('myapp:index') # 删除完成后的重定向 URL template_name = 'myapp/my_model_confirm_delete.html' # 确认删除的模板 ``` 3. 定义模板 在模板文件 `myapp/my_model_confirm_delete.html` ,可以使用以下变量: - `object`: 要删除的对象 - `object_name`: 对象的类名 - `submit_url`: 确认删除后的提交 URL 删除确认模板示例: ```html {% extends 'base.html' %} {% block content %} <h2>确认删除 {{ object_name }} "{{ object }}" ?</h2> <form method="post" action="{{ submit_url }}"> {% csrf_token %} <button type="submit">删除</button> <a href="{{ object.get_absolute_url }}">取消</a> </form> {% endblock %} ``` 4. 定义 URL ```python from myapp.views import MyModelDeleteView urlpatterns = [ # ... path('my-model/<int:pk>/delete/', MyModelDeleteView.as_view(), name='my_model_delete'), # ... ] ``` 在模板使用 `object.get_absolute_url` 可以实现取消删除操作。如果没有定义 `get_absolute_url` 方法,则需要在模板手动指定取消操作的 URL。 这就是 DeleteView 的基本用法。可以通过重写 DeleteView 的方法来自定义删除操作的行为。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值