Django 中url补充以及模板继承

简介: Django中的URL补充 默认值 在url写路由关系的时候可以传递默认参数,如下: url(r'^index/', views.index,{"name":"root"}), 这样在视图函数中,就可以获取这个默认参数name: def index(request,name): ...

Django中的URL补充

默认值

在url写路由关系的时候可以传递默认参数,如下:

url(r'^index/', views.index,{"name":"root"}),

这样在视图函数中,就可以获取这个默认参数name:

def index(request,name):
    print(name)
    return  HttpResponse("%s is OK" %name)

命名空间

通过下面例子理解:

在项目的urls里写入如下代码:

urlpatterns = [

    url(r'^a/',include("app01.urls",namespace="author"))

]

在app的urls里写入如下代码:(注意高亮部分必须有)

app_name = "app01"
urlpatterns = [
    url(r'^index/',views.index,name="index")
]

最后在views视图函数中写入如下代码:

from django.urls import reverse

def index(request):
    v = reverse("author:index")
    print(v)
    return  HttpResponse("is ok")

当访问页面

 

 

关于获取用户请求信息

 

我们在视图函数中写的函数中都加了一个request参数,我们可以通过from django.core.handlers.wsgi import WSGIRequest 导入之后通过request.environ查看详细的信息

而request.environ是一个字典我们循环之后打印:

 

    for k,v in (request.environ).items():
        print(k,v)

则可以看到整个请求头的信息

模板继承

 

 

 

如果自己的网站中每个页面都有上面这个部分,如果我们在每个页面都重复写这段代码就会很麻烦,并且改动起来也需要每个都改动,为了这种需求,模板继承可以解决这个问题

把相同的东西写入到模板中,如果某个部分不同则:

{% block content(这里是自定义名字) %}{% endblock %}

而在要继承模板的代码中首先:

{% extends "tp.html" %}  表示要继承的模板

 

{% block content(这个名字和在模板中定义的名字保持一致) %}

<h1>用户管理</h1>

{% endblock %}

这样就继承了模板中的内容

具体代码如下:

模板中代码如下tp.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{% block title %}{% endblock %}</title>
    <link rel="stylesheet" href="/static/common.css">
</head>
<body>
    <div class="pg-header">
        我的网站
    </div>
    {% block content %}{% endblock %}
</body>
</html>

tp1.html继承tp.html代码如下:

{% extends "tp.html" %}
{% block title %}
    主机管理
{% endblock %}

{% block content %}
<h1>用户管理</h1>
{% endblock %}

tp2.html继承tp.html,代码如下:

{% extends "tp.html" %}
{% block title %}
    用户管理
{% endblock %}

{% block content %}
<h1>用户管理</h1>
{% endblock %}

这样最后登录tp1和tp2的效果如下:

 

这样就实现了继承,但是这里有个问题,如果tp1和tp2中自己想写自己单独的css以及js的话,就需要做如下操作:

在head的最下面写如下代码:

{% block css %}{% endblock %}

在body的最下面写如下代码:

{% block js %}{% endblock %}

 

这样在tp1以及tp2中就可以自定义自己的css

例如在tp1中添加如下代码:

 

{% block css %}
    <style>
        body{
            background-color: red;
        }
    </style>

这样再次访问tp1.html的时候效果如下,而访问tp2的时候效果不会发生变化:

 

include

 

当有一些小的标签很多页面都需要用到的时候我们可以单独在一个html中将写标签,在tp1中以及tp2中通过include调用

具体如下,新添加一个tag.html,代码如下:

<form>
    <input type="text">
    <input type="text">
</form>

在tp1.html中代码如下:

{% block content %}
<h1>用户管理</h1>
{% include "tag.html" %}
{% endblock %}

这样最后的效果如下:

 

所有的努力都值得期许,每一份梦想都应该灌溉!
目录
相关文章
|
SQL 前端开发 JavaScript
Python 教程之 Django(10)模板
Python 教程之 Django(10)模板
192 0
|
前端开发 JavaScript 数据库
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
|
JSON 数据处理 API
Django后端架构开发:视图与模板的正确使用
Django后端架构开发:视图与模板的正确使用
311 1
|
前端开发 Python
Django模板
【8月更文挑战第19天】
146 3
|
自然语言处理 前端开发 数据处理
Django的模板系统
【8月更文挑战第13天】
183 2
|
Java C++ Python
django 模板 过滤器
django 模板 过滤器
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
501 0
|
前端开发 数据处理 开发者
解锁Django模板系统终极奥义!揭秘高效前端渲染秘籍,让你的网站秒变炫酷黑科技!
【8月更文挑战第31天】Django作为Python的高级Web框架,内置的模板系统支持动态HTML渲染。本文通过在线书店案例,详细介绍Django模板系统的设置与高效渲染技巧,包括创建模板文件、编写视图函数及URL配置。通过合理使用过滤器、深度查询和模板继承等技巧,提升前端渲染效率和安全性,优化Web应用开发流程。
209 0
|
Python
列出 Django 中的继承样式
【8月更文挑战第30天】
121 0
|
安全 JavaScript 前端开发
Django入门到放弃之模板及标签
Django入门到放弃之模板及标签