首页 > 其他分享 >框架第五课---模板层之标签,自定义过滤器、标签及inclusion_tag(了解),模板的继承与导入,模型层之ORM常见关键字

框架第五课---模板层之标签,自定义过滤器、标签及inclusion_tag(了解),模板的继承与导入,模型层之ORM常见关键字

时间:2022-12-14 14:56:54浏览次数:60  
标签:自定义 models 标签 filter objects User res 模板

昨日内容回顾

  • 路由分发

    总路由不再直接参与路由与视图函数/类的匹配关系 
    
    总路由
    	path('app01/',include('app01.urls'))
    子路由
    	path('index/',views.index_func)
    
  • 名称空间

    主要用于路由分发之后别名冲突反向解析无法准确的情况
    总路由
    	namespace
    反向解析
    	{% url 'app01:index_view' %}
     	reverse('app01:index_view')
    只要保证整个项目中别名不冲突就可以不使用名称空间
    	应用名作为别名前缀
    
  • 虚拟环境

    给不同的python项目提供准确的独一无二的开发环境
    1.pycharm创建
    2.命令行创建
    	python -m venv 解释器名称
    	激活、关闭(scripts)
    ps:requirements.txt
    
  • 视图层之三板斧

    视图函数或者视图类中绑定方法(处理网络请求)最后都必须返回HttpResponse对象
    from django.shortcuts import HttpResponse,render,redirect
    
  • 视图层之JsonResponse

    from django.http import JsonResponse
    
    """
    class JsonResponse:
    	def __init__(self,data,json_dumps_params=None,safe=True):
    		if json_dumps_params == None:
    			json_dumps_params = {}
    		json.dumps(data,**json_dumps_params)
    """
    
  • 视图层之获取文件数据

    form标签携带文件数据需要注意的两个地方
    	method改为post
     	enctype改为multiple/form-data
    django后端获取数据
    	request.POST   普通数据
     	request.FILES  文件数据
    
  • 视图层之FBV与CBV

    FBV	基于函数的视图
    	path('index/',视图函数的函数名)
     	def index_func(request):return HttpResponse()
    CBV 基于类的视图	
    	path('func/',视图类名.as_view())
     	from django import views
    	class MyFuncView(views.View):
            def get(self,request):
                return HttpResponse()
      		  def post(self,request):
                return HttpResponse()
     	CBV会根据不同的请求方法自动匹配类中定义的方法并执行
    
  • CBV源码剖析

    1.CBV路由匹配
    	path('func/',视图类名.as_view())
    	class View:
            @classonlymethod
            def as_view(cls):
                def view():
                    pass
                return view
     	path('func/',view)  # 本质还是FBV的匹配方式
    2.路由一旦匹配到了func就会自动触发view函数的执行
    	def view():
            obj = cls()
            return obj.dispatch()
    3.执行dispatch方法(可以拦截并扩展)
    	def dispatch():
            handler = getattr(obj,request.method.lower())
            return handler()
    
  • 模板层之模板传值

    render(request,'login.html',{'name':'jason','age':18})
    render(request,'login.html',locals())
    
  • 模板层之传值特性

    1.python基本数据类型及文件名、对象名都可以传递
    2.函数名和类名会自动加括号调用(不支持传参)
    
  • 模板层之过滤器

    |add
    |length
    |slice
    |date
    |truncatewords
    |truncatechars
    |filesizeformat
    |safe
    

今日内容概要

  • 模板层之标签
  • 自定义过滤器、标签及inclusion_tag(了解)
  • 模板的继承与导入
  • 模型层之ORM常见关键字
  • 模型层之外键字段
  • 模型层之外键字段数据增删改查

今日内容详细

模板层之标签

{% if 条件1(可以自己写也可以用传递过来的数据) %}
        <p>今天又是周三了</p>
{% elif 条件2(可以自己写也可以用传递过来的数据) %}
        <p>百日冲刺</p>
{% else %}
        <p>没多少时间了!</p>
{% endif %}


{% for k in t1 %}
        {% if forloop.first %}
            <p>这是我的第一次循环{{ k }}</p>
        {% elif forloop.last %}
            <p>这是我的最后一次循环{{ k }}</p>
        {% else %}
            <p>这是中间循环{{ k }}</p>
        {% endif %}
        
        {% empty %}
            <p>你给我传的数据是空的无法循环取值(空字符串、空列表、空字典)</p>
{% endfor %}

django模板语法取值操作>>>:只支持句点符
    句点符既可以点索引也可以点键
	 {{ d1.hobby.2.a1 }}
        
{% with d1.hobby.2.a1 as h %}  复杂数据获取之后需要反复使用可以起别名
        <a href="">{{ h }}</a>
{% endwith %}

自定义过滤器、标签及inclusion_tag(了解)

"""
如果想要自定义一些模板语法 需要先完成下列的三步走战略
	1.在应用下创建一个名字必须叫templatetags的目录
	2.在上述目录下创建任意名称的py文件	
	3.在上述py文件内先编写两行固定的代码
		from django import template
		register = template.Library()
"""
# 自定义过滤器(最大只能接收两个参数)
@register.filter(name='myadd')
def func1(a, b):
    return a + b
{% load mytags %}
<p>{{ i|myadd:1 }}</p>


# 自定义标签(参数没有限制)
@register.simple_tag(name='mytag')
def func2(a, b, c, d, e):
    return f'{a}-{b}-{c}-{d}-{e}'
{% load mytags %}
{% mytag 'jason' 'kevin' 'oscar' 'tony' 'lili' %}



# 自定义inclusion_tag(局部的html代码)
@register.inclusion_tag('menu.html',name='mymenu')
def func3(n):
    html = []
    for i in range(n):
        html.append('<li>第%s页</li>'%i)
    return locals()
{% load mytags %}
{% mymenu 20 %}

模板的继承与导入

模板的继承(重要)
	多个页面有很多相似的地方 我们可以采取下列方式
    	方式1:传统的复制粘贴
  		方式2:模板的继承
			1.在模板中使用block划定子板以后可以修改的区域
            	{% block 区域名称 %}
               {% endblock %}
       	   2.子板继承模板
        		 {% extends 'home.html' %}
            	{% block 区域名称 %}
                	子板自己的内容
               {% endblock %}
  		ps:模板中至少应该有三个区域
            	页面内容区、css样式区、js代码区
		补充:子板也可以继续使用模板的内容 
            	{{ block.super }}

模板的导入(了解)
	将某个html的部分提前写好 之后很多html页面都想使用就可以导入
 		{% include 'myform.html' %}

模型层之前期准备

1.自带的sqlite3数据库对时间字段不敏感 有时候会展示错乱 所以我们习惯切换成常见的数据库比如MySQL django orm并不会自动帮你创建库 所以需要提前准备好

2.单独测试django某个功能层
	默认不允许单独测试某个py文件  如果想要测试某个py文件(主要models.py)
 		测试环境1:pycharm提供的python console
 		测试环境2:自己搭建(自带的test或者自己创建)
            	1.拷贝manage.py前四行
           		2.自己再加两行
                	import django
               		django.setup()
                
3.django orm底层还是SQL语句 我们是可以查看的
	如果我们手上是一个QuerySet对象 那么可以直接点query查看SQL语句
 	如果想查看所有orm底层的SQL语句也可以在配置文件添加日志记录

ORM常用关键字

# 1.create()  创建数据并直接获取当前创建的数据对象
    # res = models.User.objects.create(name='阿兵', age=28)
    # res = models.User.objects.create(name='oscar', age=18)
    # res = models.User.objects.create(name='jerry', age=38)
    # res = models.User.objects.create(name='jack', age=88)
    # print(res)
    # 2.filter()  根据条件筛选数据  结果是QuerySet [数据对象1,数据对象2]
    # res = models.User.objects.filter()
    # res = models.User.objects.filter(name='jason')
    # res = models.User.objects.filter(name='jason', age=19)  # 括号内支持多个条件但是默认是and关系
    # 3.first() last()  QuerySet支持索引取值但是只支持正数 并且orm不建议你使用索引
    # res = models.User.objects.filter()[1]
    # res = models.User.objects.filter(pk=100)[0]  # 数据不存在索引取值会报错
    # res = models.User.objects.filter(pk=100).first()  # 数据不存在不会报错而是返回None
    # res = models.User.objects.filter().last()  # 数据不存在不会报错而是返回None
    # 4.update()  更新数据(批量更新)
    # models.User.objects.filter().update()     批量更新
    # models.User.objects.filter(id=1).update() 单个更新
    # 5.delete()  删除数据(批量删除)
    # models.User.objects.filter().delete()      批量删除
    # models.User.objects.filter(id=1).delete()  单个删除
    # 6.all()     查询所有数据    结果是QuerySet [数据对象1,数据对象2]
    # res = models.User.objects.all()
    # 7.values()  根据指定字段获取数据    结果是QuerySet [{},{},{},{}]
    # res = models.User.objects.all().values('name')
    # res = models.User.objects.filter().values()
    # res = models.User.objects.values()
    # 8.values_list()   根据指定字段获取数据  结果是QuerySet [(),(),(),()]
    # res = models.User.objects.all().values_list('name','age')
    # 9.distinct()   去重 数据一定要一模一样才可以 如果有主键肯定不行
    # res = models.User.objects.values('name','age').distinct()
    # 10.order_by()  根据指定条件排序  默认是升序 字段前面加负号就是降序
    # res = models.User.objects.all().order_by('age')
    # print(res)
    # 11.get()   根据条件筛选数据并直接获取到数据对象  一旦条件不存在会直接报错 不建议使用
    # res = models.User.objects.get(pk=1)
    # print(res)
    # res = models.User.objects.get(pk=100, name='jason')
    # print(res)
    # 12.exclude()  取反操作
    # res = models.User.objects.exclude(pk=1)
    # print(res)
    # 13.reverse()  颠倒顺序(被操作的对象必须是已经排过序的才可以)
    # res = models.User.objects.all()
    # res = models.User.objects.all().order_by('age')
    # res1 = models.User.objects.all().order_by('age').reverse()
    # print(res, res1)
    # 14.count()  统计结果集中数据的个数
    # res = models.User.objects.all().count()
    # print(res)
    # 15.exists()  判断结果集中是否含有数据 如果有则返回True 没有则返回False
    res = models.User.objects.all().exists()
    print(res)
    res1 = models.User.objects.filter(pk=100).exists()
    print(res1)

作业

1.优化用户增删改查功能页面 使用上模板的继承等操作
2.整理今日内容及博客
3.复习MySQL相关查询语句

标签:自定义,models,标签,filter,objects,User,res,模板
From: https://www.cnblogs.com/tengyifan888/p/16982150.html

相关文章

  • 自定义mybatis框架
    自定义mybatis框架自定义mybatis框架整体思路如下:首先我们需要获取一个输入流然后解析我们的xml主配置文件这里面主要涉及到数据库的连接信息和我们的mapper配置文件信......
  • 新增自定义前缀
    新增自定义前缀1.设置->自定义项2.选择发布者3.新建4.填写信息项,保存即可......
  • vscode 配置模板
    1.mac:command+shift+p打开搜索面板2.输入snippets,选择代码片段:配置用户代码片段一、vue模板配置 1.选择vue.json,在body里输入需要生成的模板 ......
  • WPF使用WindowChrome自定义标题栏
    第一步:基本实现添加Window的Style定义,并设置WindowChrome.WindowChrome属性;设置WindowChrome标题栏:CaptionHeight——主要用于拖动有效区;GlassFrameThickness——影......
  • 写过vue自定义指令吗,原理是什么?.m
    背景看了一些自定义指令的文章,但是探究其原理的文章却不多见,所以我决定水一篇。如何自定义指令?其实关于这个问题官方文档上已经有了很好的示例的,我们先来温故一下。除......
  • VCL界面组件DevExpress VCL v22.1 - 支持新的格式标签和矢量图标
    DevExpressVCL是Devexpress公司旗下最老牌的用户界面套包,所包含的控件有:数据录入、图表、数据分析、导航、布局等。该控件能帮助您创建优异的用户体验,提供高影响力的业务......
  • 自定义RBAC(5)
    您好,我是湘王,这是我的博客园,欢迎您来,欢迎您再来~ 把实体类及Service类都准备好了之后,就可以开始继续写业务代码了。Spring Security的强大之一就在于它的拦截器。那么这......
  • 视图层必会三板斧、JsonResponse对象、视图层之FBV和CBV、CBV源码解剖、模板层前戏
    视图层之必会三板斧JsonResponse对象视图层之request对象获取文件视图层之FBV与CBVCBV源码剖析(重要)模板层视图层之必会三板斧#用来处理请求的视图......
  • #yyds干货盘点#【愚公系列】2022年12月 微信小程序-自定义导航栏功能的实现
    前言导航栏是指位于页面顶部或者侧边区域的,在页眉横幅图片上边或下边的一排水平导航按钮,它起着链接站点或者软件内的各个页面的作用。小程序原生导航栏的限制除了胶囊按......
  • 盒子模型和标签的标准流
    盒子模型页面中的每一个标签,都可以看做事一个盒子浏览器在渲染(显示)网页时,会将网页中的元素看做是一个个的矩形区域,所以称之为盒子盒子模型的组成CSS中的盒子分别......