使用模板变量:

在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. Chrome 浏览器垃圾回收机制与内存泄漏分析

    Chorme 浏览器中的垃圾回收和内存泄漏 垃圾回收 通常情况下,垃圾数据回收分为手动回收和自动回收两种策略. 手动回收策略,何时分配内存.何时销毁内存都是由代码控制的. 自动回收策略,产生的垃圾数据 ...

  2. VSCode 安装 code 命令

    VSCode 提供 code 命令直接从命令行中打开文件目录,此时需要先安装 code 命令. 1.首先打开 VSCode 2.使用 command + shift + p (注意window 下使用 ...

  3. Linux用到的常用命令

    Linux常用命令        

  4. sql查询入门

    SQL语言是一门相对来说简单易学却又功能强大的语言,它能让你快速上手并很快就能写出比较复杂的查询语句.但是对于大多数开发者来说,使用SQL语句查询数据库的时候,如果没有一个抽象的过程和一个合理的步骤, ...

  5. 详解Java8 Optional类{最全}

    1:Optional 1.1 概述 Optional 类主要解决的问题是臭名昭著的空指针异常(NullPointerException),提供了一些的方法代替过去的if-else处理逻辑,并与Stre ...

  6. Spring框架 --- 深入

    1.Spring IOC IOC技术: 控制反转,也叫(依赖注入) 控制反转:Bean的生命周期不受你控制,而是交给Spring容器管理. Spring框架如何利用IOC ?:        实现了控 ...

  7. Eureka error "java.net.UnknownHostException:

    spring cloud 中zuul智能路由,本地部署没有问题,部署到服务器就报com.netflix.zuul.exception.ZuulException: Forwarding error 项 ...

  8. node项目发布+域名及其二级域名配置+nginx反向代理+pm2

    学习node的时候也写了一些demo.但是只是限于本地测试,从来没有发布.今天尝试发布项目. 需要准备的东西 node 项目:为了突出重点,说明主要问题.我只是拿express 写了很简单的demo. ...

  9. 基于appium实现的线性代码引用unittest单元测试框架

    在前段时间,分享了几篇关于appium基础的博文,再加上期间也有讲到unittest测试框架,所以今天就来一个专题,在appium+python实现的线性代码基础上,引入unittest框架,使代码更 ...

  10. JS旋转和css旋转

    js旋转 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <styl ...