Django视图层:URL的反向解析(主路由include之namespace,子路由之name,模板标签{%url%},视图reverse()函数,反向解析示例,URL命名空间

一、视图层The view layer

Django 具有 “视图” 的概念,负责处理用户的请求并返回响应。
在这里插入图片描述

二、URL反向解析Reverse resolution of URLs

在这里插入图片描述
问题:随着功能的增加会出现更多的视图,可能之前配置的正则表达式不够准确,于是就要修改正则表达式,但是正则表达式一旦修改了,之前所有对应的超链接都要修改,真是一件麻烦的事情,而且可能还会漏掉一些超链接忘记修改,有办法让链接根据正则表达式动态生成吗? 动态获取url,就是用反向解析的办法。

Django 提供了一个解决方案,使得URL映射是URL设计唯一的仓库。你使用 URLconf 来填充它,然后可以双向使用它:

  • 从用户/浏览器请求的URL开始,调用对应的Django视图,并从URL中提取参数需要的值。
  • 从相应的Django视图标识(如名称)以及要传递给它的参数来获取相关联的URL 。

第一条我们在前面的章节已经讨论过。第二条就是所谓的反向解析URL,反向 URL匹配,反向URL查找,或简称URL反向

应用范围:①模板中的超链接;②视图中的重定向

使用方法:
①在工程目录下的urls,为include()函数定义namespace属性,namespace=“xxx” 。re_path(r'^Two/', include('Two.urls',namespace="fan"))
②在app目录下的urls,app_name = "appname",然后为url定义name属性,name =‘xxx’。使用时,在模板中使用url标签,
③在模板里:使用url模板标签{% url "namespace:name" %}。(也就是写前端网页时)
④在视图中使用reverse()函数,根据正则表达式动态生成地址
⑤在模型model中,get_absolute_url()方法。
path(route, view, kwargs=None, name=None, Pattern=None)
include(arg, namespace=None)
reverse(viewname, urlconf=None, args=None, kwargs=None, current_app=None)

跳转方式:
①如果需要带参跳转,如果参数是位置参数,使用args参数
②如果参数是关键字参数,使用kwargs 以字典的形式传送参数
③超链接跳转: <a href = ' {% url ' namespace: name ' %}'></a>
④在视图函数views中跳转:
1, 使用HttpResponseRedirect(‘路径地址’)—>固定获取(地址值固定不变)
2, 使用HttpResponseRedirect( reverse( ‘namespace: name’ ) )方法,动态获取(反向解析)

三、硬编码方式下的情形

在这里插入图片描述

# 工程主目录myproject/urls.py
from django.urls import path, include  # 总路由里才会有include

urlpatterns = [
    path("", include("mysite.urls")),
]
# app目录mysite/urls.py
from django.urls import path
from mysite import views

urlpatterns = [
    path("getblog/", views.get_blog),
    path("sendinfo/", views.send_info),
]
# mysite/views.py
from django.shortcuts import render

def get_blog(request):
    return render(request, "blog1.html")

def send_info(request):
    return render(request, "blog2.html")

# templates/blog1

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>第一篇博客</title>
</head>
<body>
    <p>getblog → views.get_blog → blog1.html测试超链接,跳转成功!</p>
</body>
</html>

# templates/blog2

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值