使用模板变量:

在html文件中,{{title}}即为模板变量,

在view.py文件中,render函数,增加第三个参数,以字典形式给值。

def index(req):
return render(req, 'index1.html', {'title': 'mypage', 'user': 'tom'})

可以将‘mypage’,‘tom’改成变量,实现接口和动态;

该变量可以是基本变量(单值)、字典、list、类等,在html中可以索引{{user.key}}

字典

def index(req):
user = {'name':'tom', 'age':, 'sex':'male'}
return render(req, 'index1.html', {'title': 'mypage', 'user': user})

对象

(可以使用的对象属性、方法),在调用对象的方法时,注意没有参数,要有return

def index(req):
user = Person('tom', , 'male')
return render(req, 'index1.html', {'title': 'mypage', 'user': user})

在html中存在优先级:先基本变量,再字典、对象的属性、对象的方法、最后列表

模板标签的使用:

{% if xx%}

{% else %}

{% endif %}

判断条件xx:

  • 可以是变量,判断变量是否存在
  • 可以是boolean操作, 使用and、or、not;注意不能使用();django1.3不可以and和or连用,django1.11可以
  • 可以是关系运算,等于,不等于,大小,大于等于等,注意:必须要有空格隔开!
  • 可以是in、not in运算

{% for book in book_list %}
<li>book</li>

{% empty %}  #可以没有这句

book_list为空
{% endfor %}

  • 被遍历对象可以是llist
  • 对字典遍历,跟python对dict遍历一样,for u in user得到键的遍历,for k, v in user.items: {{k}} {{v}}
  • 可以是复合数据类型
forloop.counter

序号,从1开始

forloop.counter0 

从0开始

forloop.revcounter  

反向

forloop.revcounter0

反向

forloop.first

True if the firsh through the loop

forloop.last  
forloop.parentloop

for nested loops, this is the loop 'above' the current one

  • for ... empty

使用模板:

#from django.shortcuts import render
#coding:utf-
#from django.shortcuts import render
from django.template import loader, Context, Template
from django.http import HttpResponse # Create your views here.
def index(seq):
t = loader.get_template('index.html') #加载模板,用文件
c = Context({'uname': 'alen'}) #生成Context对象
html = t.render(c) #渲染
return HttpResponse(html) #输出,我的测试报错!没找到问题 def index1(req):
t = Template('<h1>hello {{uname}}</h1>') #用字符串,生成模板对象
c = Context({'uname':'csvt'})
html = t.render(c) #渲染
return HttpResponse(html) #输出,测试成功

以上两种方法,被简化为使用render方法

1.3使用的是from django.shortcuts import render_to_response

django_2:模板的更多相关文章

  1. Jade模板引擎让你飞

    写在前面:现在jade改名成pug了 一.安装 npm install jade 二.基本使用 1.简单使用 p hello jade! 渲染后: <p>hello jade!</p ...

  2. ABP入门系列(2)——通过模板创建MAP版本项目

    一.从官网创建模板项目 进入官网下载模板项目 依次按下图选择: 输入验证码开始下载 下载提示: 二.启动项目 使用VS2015打开项目,还原Nuget包: 设置以Web结尾的项目,设置为启动项目: 打 ...

  3. CMS模板应用调研问卷

    截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...

  4. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  5. 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送

    微信支付之微信模板消息推送                    今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...

  6. OpenCV模板匹配算法详解

    1 理论介绍 模板匹配是在一幅图像中寻找一个特定目标的方法之一,这种方法的原理非常简单,遍历图像中的每一个可能的位置,比较各处与模板是否“相似”,当相似度足够高时,就认为找到了我们的目标.OpenCV ...

  7. 前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定

    一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.AngularJS是框架而jQuery则是库. 1.2. ...

  8. ThinkPHP+Smarty模板中截取包含中英文混合的字符串乱码的解决方案

    好几天没写博客了,其实有好多需要总结的,因为最近一直在忙着做项目,但是困惑了几天的Smarty模板中截取包含中英文混合的字符串乱码的问题,终于解决了,所以记录下来,需要的朋友看一下: 出现乱码的原因: ...

  9. ThinkPHP 模板substr的截取字符串函数

    ThinkPHP 模板substr的截取字符串函数在Common/function.php加上以下代码 /** ** 截取中文字符串 **/ function msubstr($str, $start ...

随机推荐

  1. 基于canvas实现钟表

    原理说明 1.通过arc方法实现钟表外环: 2.通过line实现钟表时针,分针,秒针和刻度标志的绘制,基于save和restore方法旋转画布绘制不同角度的指针: 3.通过font方法实现在画布上绘制 ...

  2. 在树莓派上安装Theano

    “查遍全网都没人成功在树莓派安装Theano,这是什么样的感觉?” ——写在开头 在这里必须先说一下,由于安装过程中的坑太多了,遇到的问题层出不穷,所以我这里只能记录我安装过程中的印象深刻的问题,如果 ...

  3. 【Spring Cloud】微服务架构选型方案

    1.技术架构 2.组件介绍 1.服务注册与发现——Eureka 服务注册与发现中心采用Eureka,以AP为核心的高可用注册中心,保证高可用性和最终一致性,server之间互相注册的replicate ...

  4. IDEA配置maven+错误记录

    使用maven并不是那么顺利所以把自己遇到的问题也记录一下 下载maven 从官网下载maven官网 配置环境变量 新建一个变量名:MAVEN_HOME 值:maven目录 path:%MAVEN_H ...

  5. django-模板之过滤器Add(十三)

    1.add 若前后类型不匹配,就返回空. 其他的一些过滤器: first:返回列表的第一个值: last:返回列表的最后一个值: length:返回变量值的长度: linebrakebr:将纯文本中的 ...

  6. 替换dom操作

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. fenby C语言 P31 使用数组的指针

    ++p代表p=p+1; #include <stdio.h> int main(void){ int a[5],i; for(i=0;i<5;i++) *(a+i)=1; print ...

  8. 如何让OKR实践变得更简单一些

    什么是OKR 近几年OKR的概念在国内开始流行起来了,之前公司也有人想实施OKR,但现在看来之前的OKR实施者只是在哪儿看了一下OKR的资料,本着跟老板邀功的想法比较功利的在推进,所以基本没有效果,今 ...

  9. 前端技术之:使用webpack构建React程序配置方法

    package.json中需要引入以下依赖:   开发依赖: "@babel/core": "^7.1.2", "@babel/preset-env& ...

  10. DataGridView内容居中显示

    DataGridView1.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter '标 ...