模版变量、过滤器、静态文件引入

模板路径

# 模板设置
TEMPLATES = [
  {
       'BACKEND': 'django.template.backends.django.DjangoTemplates',
       'DIRS': [os.path.join(BASE_DIR,'templates')],
       'APP_DIRS': True,
       'OPTIONS': {
           'context_processors': [
               'django.template.context_processors.debug',
               'django.template.context_processors.request',
               'django.contrib.auth.context_processors.auth',
               'django.contrib.messages.context_processors.messages',
          ],
      },
  },
]

模板查找顺序:优先在DIRS设置的目录下查找templates,如果没有并且 'APP_DIRS': True时,继续在注册的app文件下查找templates。

app注册后才能查找内部模板

#app注册
INSTALLED_APPS = [
   'teacher',  # 注册teacherAPP
   'django.contrib.admin',
   'django.contrib.auth',
   'django.contrib.contenttypes',
   'django.contrib.sessions',
   'django.contrib.messages',
   'django.contrib.staticfiles',
]

模板变量

模板变量命名:同变量命名规则,且不能以下划线(_)开头

def test(request):
   # tp = get_template('teacher/index.html')
   # html = tp.render()
   # return HttpResponse(html)
   def num():
       a = 1 + 2 + 3
       return a
   time = datetime.now()
   li = [1,2,3]
   dic = {'name': 'haha', 'age': 18}
   tup = (1,2,3)
   return render(request, 'teacher/index.html',context={
       'li': li,
       'time': time,
       'num': num,
       'dic': dic,
       'tup': tup,
  })

html文件:

<body>
   <p>变量a:{{ time }}</p>
   <p>列表li:{{ li }}</p>
   <p>列表中的值:{{ li.2 }}</p>
   <p>函数num:{{ num }}</p>
   <!--调用函数时,函数不能带参数-->
   <!--调用函数、表达式时,会直接返回结果-->
   <p>字典:{{ dic }},字典中的值:{{ dic.name }}</p>
   <p>字典方法:{{ dic.keys }}</p>
<!--当属性/方法名与键名冲突时,优先调用键名-->
   <p>元组:{{ tup }},值:{{ tup.1 }}</p>
</body>
<!--调用渲染失败是会返回空字符' '-->
运行结果:
变量time:Feb. 19, 2019, 3:17 p.m.
列表li:[1, 2, 3]
列表中的值:3
函数num:6
字典:{'name': 'haha', 'age': 18},字典中的值:haha
字典方法:dict_keys(['name', 'age'])
元组:(1, 2, 3),值:2

过滤器filter

常用模板过滤器 add 将参数与值相加 首先尝试转换成整数相加,失败,则尝试所有可能,字符串,列表等。 {{ value|add:"2" }}

capfirst 首字母大写,如果第一个字母不是字母则不起作用。 {{ value|capfirst }}

date 日期格式化 {{ value|date:"D d M Y" }} time 时间格式化 {{ value|time:"H:i" }} 格式化格式见官方文档: https://docs.djangoproject.com/en/2.1/ref/templates/builtins/#date

default 如果变量解析失败,使用给定的默认值。 {{ value|default:"nothing" }}(注意如果value是''空字符串,输出将会是'nothing')

first 返回列表的第一个元素 {{ value|first }}

last 返回列表的最有一个元素 {{ value|last }}

slice 返回一个列表的切片 {{ some_list|slice:":2" }}

join 连接字符串列表 与str.join(list)一样 {{ value|join:" // " }}

floatformat 浮点数格式化 不指定小数位参数,默认保留一个为小数 ​(四舍五入)

length 返回字符串或列表的长度

length_is 判断字符串或列表长度是否指定的值,相等返回True {{ value|length_is:"4" }}

lower 字符串中的字母都变小写{{ value|lower }}

upper 字符串中的字母都变大写{{ value|upper }}

safe 关闭变量的自动转义,使html标签生效{{ value|safe }}

title 标题化,首字母大写 {{ value|title }}

{#模板变量#}
   <p>变量time:{{ time }}</p>
   <p>列表li:{{ li }}</p>
   <p>列表中的值:{{ li.2 }}</p>
   <p>函数num:{{ num }}</p>
   <p>字典:{{ dic }},字典中的值:{{ dic.name }}</p>
   <p>字典方法:{{ dic.keys }}</p>
   <p>元组:{{ tup }},值:{{ tup.1 }}</p>
  {#过滤器#}
   <p>add:a+b={{ a|add:b }}</p>
   <p>capfirst:{{ li.3|capfirst }}</p>
   <p>data:{{ time|date:'Y-m-d H:i:s' }}</p>
   <P>default:{{ hhh|default:'nothing' }}</P>
   <p>first:{{ li|first }}</p>
   <p>last:{{ li|last }}</p>
   <p>slice:{{ li|slice:'::-1' }}</p>
   <p>join:{{ li|join:'00' }}</p>
   <p>floatformat:{{ 3.1415926|floatformat:3 }}</p>
   <p>length is 4:{{ li|length_is:4 }}</p>
   <p>upper:{{ li.3|upper }}</p>
   <p>title:{{ 'this is a test'|title}}</p>
   <p>safe:{{ '<h1>666<h1>'|safe }}</p>

静态文件引入

(css,js,图片文件)

路径配置:settings文件中

# 引入文件时使用的目录
STATIC_URL = '/my_static/'
# 静态文件的真实目录
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

文件引入:

1、硬编码:

<link rel="stylesheet" href="/my_static/teacher/index.css">

2、模板标签:(推荐)

<!--加载static-->
{% load static %}
<link rel="stylesheet" href="{% static 'teacher/css/index.css' %}">

 

猜你喜欢

转载自www.cnblogs.com/pingfansir/p/10402699.html
今日推荐