day51:django:dispatch&模板渲染&过滤器&标签&组件&静态文件配置
目录
dispatch
回顾:CBV对应的URL传参
urls.py
url(r'^book/(\d+)/(\d+)/', views.Book.as_view()),
views.py
from django.shortcuts import render, HttpResponse
from django.views import View class Book(View):
def get(self,request, year, month):
return HttpResponse(year+ month + '书籍') def post(self,request,year, month):
pass
CBV的实质中提到了dispatch方法
Django的url是将一个请求分配给可调用的function的,而不是一个class。
针对这个问题,class-based view提供了一个as_view()静态方法(也就是类方法)
调用这个方法,会创建一个类的实例,然后通过实例调用dispatch()方法
dispatch()方法会根据request的method的不同调用相应的方法来处理request(如get() ,post() 等)
dispatch在底层是如何实现的 ?
'''重点: 反射,将请求方法分发到同名的类方法去处理'''
def dispatch(self, request, *args, **kwargs):
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)
可以拓展dispatch方法
在请求方法分发给对应的类方法执行前后,做一些事情
from django.shortcuts import render, HttpResponse
from django.views import View class Book(View):
def dispatch(self, request, *args, **kwargs):
print('dispatch front')
ret = super().dispatch( request, *args, **kwargs) # 继承父类dispatch的所有内容
print('dispatch behind')
return ret def get(self,request, year, month):
print('get method')
return HttpResponse(year+ month + '书籍') def post(self,request,year, month):
pass '''执行结果'''
dispatch前
get方法
dispatch后
模板渲染
views.py
from django.shortcuts import render def home(request):
username = 'SByaya' # 可以传字符串
num = 10 # 可以传数字
lst1 = [11,22,33] # 可以传列表
dict1 = {'k1':'v1','k2':'v2'} # 可以传字典
class A:
def __init__(self):
self.name = 'yayasillydog'
def get_name(self):
return self.name + '太蠢了'
a = A() # 可以传类对象 dic = {
'username':username,
'num':num,
'lst1':lst1,
'dict1':dict1,
'a':a, } return render(request,'home.html',dic)
home.html
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
</head>
<body> <h1>Welcome to dog's home!!</h1>
<h1>{{ username }}</h1>
<h1>{{ num }}</h1>
<h1>{{ lst1 }}</h1>
<h1>{{ lst1.1 }}</h1> <!-- 用点索引来取值 -->
<h1>{{ dict1 }}</h1>
<h1>{{ dict1.k1 }}</h1> <!-- 字典.键来取值 -->
<h1>{{ a.name }}</h1> <!-- 可以获取对象里的属性 -->
<h1>{{ a.get_name }}</h1> <!-- 只能获取对象里的无参方法,不能够获取有参方法 --> </body>
</html>
过滤器
过滤器语法
语法:{{ value|filter_name:参数 }}
注意点:管道符两边不能有空格,有参数的冒号加参数,无参数的不需要冒号
常见的过滤器
1.default默认值
如果一个变量没有传值或者值为空,使用给定的默认值。 否则,使用变量的值。
没有传值
'''没有传值'''
def home(request):
username = 'yayapig' # 可以传字符串
dic = {
# 'username':username, # 没有传username
} return render(request,'home.html',dic)
值为空
'''值为空'''
username = ''
default默认值语法
<p>
{{ username|default:'Libolun' }}
</p
2.length 判断长度
<p>
{{ username|length }}
</p>
3.filesizeformat 展示为可读的大小,自动计算单位
<p>
{{ file_size|filesizeformat }}
</p>
4.slice 切片
<p>
{{ msg|slice:'0:4' }}
</p>
5.date 日期格式化
<p>
{{ current_time|date:"Y-m-d H:i:s" }} <!-- 注意分钟是用i来表示 -->
</p>
6.safe 将标签字符串识别为一个标签效果
使用safe的目的:防止xss攻击(跨站脚本攻击)
views.py
def test(requqest):
a_tag = '<a href="">某宝</a>'
return render(request,'test.html',{'a_tag':a_tag})
test.html
<p>
{{ a_tag|safe }}
</p>
7.truncatechars 字符截断
注意:7包括4个字符加3个省略号
<p>
{{ msg|truncatechars:7 }}
</p>
8.truncatewords 单词截断
<p>
{{ msg|truncatewords:2 }}
</p>
9.cut 移除value中所有的与给出的变量相同的字符串
<p>
{{ msg|cut:' ' }} <!-- 去除value中所有的空格 -->
</p>
10.join 字符串拼接
<p>
{{ list1|join:'+' }} <!-- 等同于python中的"+".join(list1) -->
</p>
标签
标签语法
语法: {% 标签逻辑 %}
for循环标签
1.循环列表
<ul>
{% for i in lst1 %}
<li>{{ i }}</li>
{% empty %}
<span>哥,啥也木有啊</span>
{% endfor %}
</ul>
<!-- 如果lst1为空,或者后台没有给lst1数据,那么就展示empty下面的内容 -->
2.循环字典
<ul>
{% for k,v in dic1.items %}
<li>{{ k }}--->{{ v }}</li>
{% endfor %}
</ul>
<!-- 在循环中,可以接dic1.keys values items -->
3.循环嵌套
<ul>
{% for i in lst1 %}
<li>{{ i }}--->{{ forloop.counter }}</li>
{% if forloop.last %}
{% for ii in i %}
<li>{{ ii }}--->{{ forloop.counter }}--->{{ forloop.parentloop.counter }}</li>
{% endfor %}
{% endif %}
{% endfor %}
</ul>
forloop用法
forloop.counter # 当前循环的索引值(从1开始),forloop是循环器,通过点来使用功能
forloop.counter0 # 当前循环的索引值(从0开始) forloop.revcounter # 当前循环的倒序索引值(从1开始)
forloop.revcounter0 # 当前循环的倒序索引值(从0开始) forloop.first # 当前循环是不是第一次循环(布尔值)
forloop.last # 当前循环是不是最后一次循环(布尔值) forloop.parentloop # 本层循环的外层循环的对象,再通过上面的几个属性来显示外层循环的计数等
if循环标签
if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断,注意条件两边都有空格。
views.py
from django.shortcuts import render def home(request):
number = 102 dic = {
'number':number,
} return render(request,'home.html',dic)
home.html
{% if number == 100 %}
<h1>猜对了</h1>
{% elif number == 101 %}
<h1>101不对呀</h1>
{% else %}
<h1>这更不对了</h1>
{% endif %}
if语句也可以和过滤配合使用
{% if user_list|length > 5 %} <!--结合过滤器来使用-->
可以可以
{% else %}
不行不行
{% endif %}
组件
组件:把完整的一套功能封装成模块
在前端中,就是把一套完整的样式封装起来,供其他人使用
在其他的html文件中引入一个html文件
在index.html中如果我们想使用已经封装好的zujian.html,该怎么引入呢?
index.html
{% include 'zujian.html' %}
zujian.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <h1 style="color:red;">这是导航栏</h1> </body>
</html>
静态文件配置
1.在项目根目录下创建一个文件夹,比如名称为xx
2.在setting.py中写入如下内容
STATIC_URL = '/static/' #别名 STATICFILES_DIRS = [
os.path.join(BASE_DIR,'jingtaiwenjian'), # 注意别忘了写逗号,第二个参数就是项目中你存放静态文件的文件夹名称
]
3.在html文件中使用别名
设置STATIC_URL的意义
别名也是一种安全机制,浏览器上通过调试台你能够看到的是别名的名字,这样别人就不能知道你静态文件夹的名字了,不然别人就能通过这个文件夹路径进行攻击。
STATIC_URL的用法
<!-- 两种引入方式 -->
<link rel="stylesheet" href="/static/css/test.css">
<link rel="stylesheet" href="{% static 'css/test.css' %}"> <!-- 导入一张图片 -->
<img src="/static/imgs/test.png" alt=""> <!-- 引入js文件 -->
<script src="/static/js/xx.js"></script>
1.在项目根目录下创建一个文件夹,比如名称为xx
2.在setting.py中写入如下内容
day51:django:dispatch&模板渲染&过滤器&标签&组件&静态文件配置的更多相关文章
- Django简介,请求生命周期,静态文件配置
Web框架 Web框架(Web framework)是一种开发框架,用来支持动态网站.网络应用和网络服务的开发.这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方 ...
- django之三剑客、静态文件配置、请求响应对象、数据库操作
三剑客 from django.shortcuts import render,HttpResponse,redirect HttpResponse # 返回字符串 render(response, ...
- django 组件 自定义过滤器 自定义标签 静态文件配置
组件 将一些功能标签写在一个html文件里,这个文件作为一个组件,如果那个文件需要就直接拿过来使用即可: 这是title.html文件,写了一个导航栏,作为一个公用的组件 <div style= ...
- day58——模板继承、组件、自定义标签和过滤器、inclusion_tag、静态文件配置、url别名和反向解析、url命名空间
day58 模板相关 模板继承(母版继承) 1. 创建一个xx.html页面(作为母版,其他页面来继承它使用) 2. 在母版中定义block块(可以定义多个,整个页面任意位置) {% block co ...
- Django 04 模板标签(if、for、url、with、autoeacape、模板继承于引用、静态文件加载)
Django 04 模板标签(if.for.url.with.autoeacape.模板继承于引用.静态文件加载) 一.if.for.url.with.autoescape urlpatterns = ...
- Django框架----模板继承和静态文件配置
母板 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...
- Django(五)框架之模板继承和静态文件配置
https://www.cnblogs.com/haiyan123/p/7731959.html 一.模板继承 目的是:减少代码的冗余 语法: {% block classinfo %} {% end ...
- Django框架之模板继承和静态文件配置
一.模板继承 目的是:减少代码的冗余 语法: {% block classinfo %} {% endblock %} 具体步骤: 1.创建一个base.html文件,2.把要显示的页面的内容写在这里 ...
- Django框架之模板基础,静态文件配置
一.模板继承 目的是:减少代码的冗余 语法: {% block classinfo %} {% endblock %} 具体步骤: 1.创建一个base.html文件,2.把要显示的页面的内容写在这里 ...
随机推荐
- 通过http、https域名访问静态网页、nginx配置负载均衡(nginx配置)
很多场景下需要可以通过浏览器访问静态网页,不想把服务器ip地址直接暴露出来,通过nginx可以解决这个问题. 实现http域名访问静态网页 1.域名解析配置(本文都是以阿里云为例,其他平台,操作步骤类 ...
- Nginx CORS 跨域资源共享问题
## 背景 新项目上线,前后端分离,遇到了跨域资源共享的问题,导致请求根本无法发送到后端,前端和后端貌似只能有一个来处理跨域问题,我们这边要采用nginx来解决跨域问题. ## Nginx的CORS配 ...
- excel表格,根据某一列的值对整行进行颜色填充
1.选中要影响的表格范围,选择 “条件格式”,选择 “新建规则” (2)选择 “使用公式确定要设置格式的单元格”,录入公式,选择 “ 格式”,注意: 公式为:=$H1="待解决" ...
- 如何在 asp.net core 的中间件中返回具体的页面
前言 在 asp.net core 中,存在着中间件这一概念,在中间件中,我们可以比过滤器更早的介入到 http 请求管道,从而实现对每一次的 http 请求.响应做切面处理,从而实现一些特殊的功能 ...
- Android Studio && GitHub 团队多人一起开发
曾几何时,花了两天的时间搞了合并项目,搞得乱七八糟der,但最终还是被我搞定了,too 乱 to 做笔记.过了几个月,也就是前几天,抱着从头开始的决心,再次尝试,然鹅并没有结果.今天,再一次重新开始, ...
- 从零开始讲解JavaScript中作用域链的概念及用途
从零开始讲解JavaScript中作用域链的概念及用途 引言 正文 一.执行环境 二.作用域链 三.块级作用域 四.其他情况 五.总结 结束语 引言 先点赞,再看博客,顺手可以点个关注. 微信公众号搜 ...
- NRF52840 添加 led service
记录NRF52840 添加LED service的流程,以及遇到的问题. 由于SDK中已经有了led service的.c和.h文件,因此只需要添加文件,并且调用相关函数即可. 注:编译调试环境为ke ...
- chained get value from nested json
static getValueByKey(o, p, defaultValue = false) { return p.split('.').reduce((r, k) => { if (typ ...
- go genetlink demo
原文链接:https://github.com/mdlayher/genetlink [root@wangjq test]# cat genetlink.go package main import ...
- Java面试题(Hibernate篇)
Hibernate 113.为什么要使用 hibernate? 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码. Hibernate是一个基于JDBC的主流持久化框架,是一个 ...