Django 中url补充以及模板继承

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 %}

这样最后的效果如下:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏开源优测

21条自动化测试过程中遭遇的问题及解决思路

1、找不到元素,脚本报“NoSuchElementException:Unable to find element”,或者"定位到了,不能操作,点击无效"

1363
来自专栏雪地二货笔记库

vue学习笔记5-事件绑定-v-on

效果也相同。 而且vue也封装了好多方法,可以用这些方法简介开发 例如@keyup.enter="a",如果按下键盘的时候按下的是回车,那么就可以直接触发a方法...

441
来自专栏cs

c++那些事儿10.0 STL--Vector

知识点综述: ---- vector:动态数组,是序列式容器。 这里只介绍vector使用,其实现可以参考数据结构,其函数可以查看stl的源码。 优点...

35711
来自专栏云霄雨霁

了解Jalangi2

1030
来自专栏Java学习网

Java8读文件方法代码学习

Java8读文件方法代码学习   JDK7中引入了新的文件操作类java.nio.file.File,它包含了很多有用的方法来操作文件,比如检查文件是否为隐藏...

34510
来自专栏九彩拼盘的叨叨叨

最近开发一个较复杂的单页应用的些许感想

该应用是所谓的前后端分离的: 前端,后端是两个项目。 启动项目时,前端只需起一个静态服务器,后端用命令行起即可。 前端负责页面输出。用了Angular.js...

572
来自专栏佳爷的后花媛

路由&模块化设计&命名空间

ThinkPHP采用模块化的架构思想,可以支持多模块应用的创建,让应用的扩展更加方便. 先简单说下路由规则:

813
来自专栏无原型不设计

Mockplus组件样式库一键解决风格复用

在Mockplus3.3版本中,新增了组件样式库,可以快速复用组件风格,同时可以将组件风格保存到库中。

20210
来自专栏枕边书

PHP模拟发送POST请求之四、加强file_get_contents()发送POST请求

使用了笨重fsockopen()方法后,我们开始在PHP函数库里寻找更简单的方式来进行POST请求,这时,我们发现了PHP的文件函数也具有与远程URL交互的功能...

1748
来自专栏Python

Python2和Python3的一些语法区别

Python2和Python3的一些语法区别 python 1.print 在版本2的使用方法是: print 'this is version 2 也可以是...

2028

扫码关注云+社区