Python学习第二十八课——Django(templates)

Posted PY憨

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python学习第二十八课——Django(templates)相关的知识,希望对你有一定的参考价值。

templates 讲后台得到的数据渲染到页面上:话不多说,先看具体代码。

urls:

from django.conf.urls import url
from django.contrib import admin
from django.urls import path

from a00 import views

urlpatterns = [
    path(\'admin/\', admin.site.urls),
    url(r\'show_time/\',views.show_time ),
    url(r\'list_bianli/\',views.list_bianli),
    url(r\'dict_bianli/\', views.dict_bianli),
    url(r"login/",views.login,name="log")


]

views:

from django.shortcuts import render, HttpResponse
import time, datetime


# Create your views here.

class Animal():
    def __init__(self,name,sex):
        self.name=name
        self.sex=sex





def show_time(request):
    t = datetime.datetime.now()
    return render(request, "show_time.html", locals())


def list_bianli(request):
    l = ["韩寒", "梅梅", "丽丽"]

    return render(request, "index.html", {"action":l}) # 遍历列表



def dict_bianli(request):
    c=Animal("alex","")

    l = ["韩寒", "梅梅", "丽丽"]
    d = {"name": "憨憨", "age": 12, "hobby": "篮球"}



    a="<a href=\'\'>click</a>"
    return render(request, "dict_bian.html",locals()) # 遍历字典



def login(requrst):
    return HttpResponse("OK")

show_time.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>时间为:{{ t }}</h1>

{#管道符  date方法 主要格式化日期#}
<h1>{{t|date:"Y-m-d"}}</h1>

</body>
</html>

 

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>Hellow {{ action.0 }}</h1>
<h1>Hellow {{ action.1 }}</h1>
<h1>Hellow {{ action.2 }}</h1>



<h1>{{ a }}</h1>
</body>
</html>

dict_bian.html:

{#在HTML中加在你的filter#}
{% load myTag %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
{#万能聚点符  可以遍历字典,列表  等等#}
<h1>Hellow {{ d.name }}</h1>  <!-- 憨憨-->
<h1>Hellow {{ d.age }}</h1>
<h1>Hellow {{ d.hobby }}</h1>
<h1>hello {{c.name}}</h1>
<h1>hello {{c.sex}}</h1>


<h1>憨的真是年龄{{d.age|add:12 }}</h1>  <!--憨的真是年龄24-->



{#第一种写法#}
<h1>{{ a|safe}}</h1> <!--相当于超链接-->


{#第二种写法#}
{% autoescape off %}
    <h1>{{ a }}</h1>
{% endautoescape %}

{#if语句#}
{#输出结果:憨憨的年龄小于12#}
{% if d.age > 18 %}
    <h1>hello {{ d.name }}</h1>
{% else %}
    <h1>{{ d.name }}的年龄小于{{ d.age }}</h1>
{% endif %}


{#for循环#}
{#输出结果:1:韩寒 2:梅梅  3:丽丽 #}

{% for name in l %}

    <h1>{{ forloop.counter0 }}:{{ name }}</h1>

      倒序输出
    <h1>{{ forloop.revcounter0 }}:{{ name }}</h1>

{% endfor %}


<form action="{% url \'log\' %}" method="post">
    <p>用户名<input type="text" name="user"></p>
    <p>密码<input type="text" name="pwd"></p>
    <p><input type="submit"></p>
{#    渲染“身份证”  解决403#}
    {% csrf_token %}

</form>


{#通过自定义过滤器来完成乘法运算#}
{{ d.age|filter_multi:3 }}  <!-- 输出结果 36  此时d.age 相当于后台 filter_multi 方法中的x ,3 才是参数y-->

{% simple_tag_multi 3 5 2 %} <!-- 30 -->

{% simple_tag_multi d.age 5 2 %} <!-- 120 -->

</body>
</html>

自定义过滤器filter:

第一步:在项目中创建一个文件夹名字叫templatetags.

 

 

 

 

第二步:在文件夹templatetags建一个.py文件,名字自定

 

 

第三步:在.py文件中写代码:

myTag.py:

from django import template  # 固定 背下来
from django.utils.safestring import mark_safe  # 固定 背下来

register = template.Library()  # register 的名字是固定的,不可改变


@register.filter
def filter_multi(x, y):  # y是参数 x不是 并且只能有一个参数
    return x * y


@register.simple_tag
def simple_tag_multi(x, y, z):  # 可以传多个参数
    return x * y * z

接着在需要用到自定义过滤器filter的HTML中运用即可:

 

 注:复制的话去前面dict_bian.html中

 

templates 中 extends 和 include 用法: 

base.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>


<style>
    *{
        margin: 0;
        padding: 0;
    }
    .nav{
        line-height: 40px;
        width:100%;
        background-color: darkblue;
        color: white;
        font-size: 20px;
        text-align: center;
    }

    .left{
        width:20%;
        min-height: 600px;
        overflow: auto;
        background-color: lightblue;
    }
    .manage{
        text-align: center;
        padding: 20px 0px;
        margin: 20px 0;
        font-size: 18px;
    }
    .content{
        width:70%;
        min-height:600px ;
    }

    a{
        text-decoration: none;
    }
    h1,h2{
        text-align: center;
    }
     .left,content{
         float: left;
     }

</style>
<body>

<div class="outer">
    <div class="nav">标题</div>

    <div class="left">
        <div class="student manage"><a  href="/student/">学生管理</a></div>
        <div class="teacher manage"><a  href="">老师管理</a></div>
        <div class="course manage"> <a  href="">课程管理</a></div>
        <div class="classes manage"><a  href="">班里管理</a></div>
    </div>

    <div class="content">
{#        相当于放了一个盒子  因为此行代码需要修改 #}
        {% block content1 %}

            <h1>WELCOME TO LOGIN</h1>

        {% endblock %}
    </div>
</div>

</body>
</html>

需要继承base.html的student2.html代码:

{#继承base.html全部代码#}

{% extends "base.html" %}


{# 修改base.html中定义的盒子#}
{% block content1 %}
{#    如果想拿父类(base.html中盒子哪儿一块)#}
    {{ block.super }}

   {% for student in student_list %}
            <h2>学生{{ student }}</h2>


        {% endfor %}
{#    在本页中在加一个Html的内容 用 include #}
    {% include "test.html" %}
{% endblock %}

 

以上是关于Python学习第二十八课——Django(templates)的主要内容,如果未能解决你的问题,请参考以下文章

第二十八课

第二十八课 再论智能指针(下)

Spring入门第二十八课

python五十八课——正则表达式(替换)

python五十八课——正则表达式(分组)

“全栈2019”Java第二十八章:数组详解(上篇)